如何解决Sybase数据库乱码问题详解

2016-01-29 15:45 5 1 收藏

如何解决Sybase数据库乱码问题详解,搭建测试数据库服务器时,遇到了乱码问题,之前没有遇到是因为开发数据库服务器是早就安装好并设置好字符集的,因此些问题在部署测试环境时才出现,当时已经将数据库配置完毕,并且所有的初始化脚本都已经执行完毕,工程也已经成功部署在 WebLogic上,打开IE,运行程序,却发现所有从数据库中读取出来的都是乱码,本例将详细讲解Sybase数据库乱码问题的解决~~

【 tulaoshi.com - SQLServer 】

搭建测试数据库服务器时,遇到了乱码问题,之前没有遇到是因为开发数据库服务器是早就安装好并设置好字符集的,因此些问题在部署测试环境时才出现,当时已经将数据库配置完毕,并且所有的初始化脚本都已经执行完毕,工程也已经成功部署在WebLogic上,打开IE,运行程序,却发现所有从数据库中读取出来的都是乱码,经过上网搜索的相关资料,需要设置字符集,但刚开始查找到的资料基本是都是支言片语,没有一个系统的讲解如何设置字符集,几乎将他们所有的方法都试过了,结果不但没有弄好,甚至连控制台和SQL平台都是乱码了,实在弄不明白了,就去问高人了,他给我发了一个专门讲解字符集的文档,讲的很全面,而且通过他的帮忙终于将解决了乱码问题。

下面我总结一下设置字符集的过程:

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/sqlserver/)

1、安装完Sybase后,如果要想设置字符集为CP936,就必须先安装该字符集,因为Sybase默认的字符集表中并没有该字符集,安装步骤如下:(这里 SYBASE的安装路径为c:sybase)   1.c:;cd sybasecharsetscp936   2.c:sybasecharsetscp936; charset -Usa -Psa_pass -Sserver_name binary.srt cp936通过上述命令就成功将CP936字符集安装表Sybase的系统字符集表中,但必须重启Sybase服务两次才能看到结果,可以通过查看 master数据库中的syscharsets表查看是否已经安装成功,我们可以看到已经安装成功了:1002,171,0,1,'cp936', 'CP936 (Simplified Chinese).',’’

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/sqlserver/)

2、看到CP936的编号为171,我们需要在Sybase的属性中设置系统字符集为该ID,如下图所示:

如果设置完字符集成出现错误,是因为master数据库的表空间默认只分配几百K的空间,导入新的数据后已经没有足够的空间了,所以要对master数据库设置大一些的表空间,点击master数据库右键属性,选择表空间的tab页,对原有的表空间编辑重新分配大小,将master所有的表空间都分配了就可以解决该问题。

3、 设置好字符集后就可以执行初始化脚本了。这其中还有几个小插曲,由于第二步的表空间不足的错误根本没有一个文档中有说明,所以我和郭立英根本谁也不知道,都以为Sybase被我们搞崩溃了呢,没办法只能重新安装,但安装后还是有该问题,后来请高人来帮我们看才知道是表空间的问题,还有就是虽然设置好字符集后,打开IE看还是乱码,不知道为什么,后来重新执行一遍脚本后就没有了,是因为之前默认的字符集为Cp850,所以用该字符集下执行的脚本再到CP936的环境中读取一定会乱码,所以在 CP936的环境中再执行一遍脚本就没有问题了。

来源:https://www.tulaoshi.com/n/20160129/1496361.html

延伸阅读
标签: Web开发
jsp   页面用下面3句语句来保证是gbk   编码   %@   page   session="true"   %     %@   page   contentType="text/html;charset=gbk"   %       %@page   pageEncoding="gbk"%&...
标签: Web开发
要解决JSP乱码,首先就要了解JSP乱码的原因 1.架设服务器安装MYSQL时的会让你选择一种编码,如果这种编码与你的网页不一致,可能就会造成JSP页面乱码 2.在PHPMYADMIN或mysql-front等系统 创建数据库时会让你选择一种编码,如果这种编码与你的网页不一致,也有可能造成JSP页面乱码 3.创建表时会让你选择一种编码,如果这种编码与你的...
标签: Java JAVA基础
  1. 单用一个 JSP 文件测试 SYBASE jconnect-5_2 JDBC 数据库接口 : <%@ page contentType="text/html;charset=GB2312" %<%@ page import="java.sql.*" %<HTML<HEAD<TITLE JSP 测试 SYBASE jconnect-5_2 JDBC 数据库接口 </TITLE<META NAME="Generator" CONTENT="EditPlus2.11"<META NAME="Au...
1.ACCESS的数据库中的自动编号类型在转化时,sql server并没有将它设为自动编号型,我们需在SQL创建语句中加上identity,表示自动编号! 2.转化时,跟日期有关的字段,SQL SERVER默认为smalldatetime型,我们最好将它变为datetime型,因为datetime型的范围比smalldatetime型大。我遇见这种情况,用smalldatetime型时,转化失败,而用...
如果你有两个数据 创建表的声明追踪, 经过TKPROF 解析后,输出结果如下: CREATE TABLE TABLE_ROWNUM AS SELECT * FROM (SELECT ID, ROWNUM AS rownum_a FROM TABLE_A) ALIAS_A, (SELECT ID AS id_b, ROWNUM AS rownum_b FROM TABLE_B) ALIAS_B WHERE ALIAS_A.rownum_a = ALIAS_B.rownum_b call count cpu elapsed disk query curren...

经验教程

192

收藏

42
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部