在dos界面中输入:isql –Usa –P111111 –Szhouyx 分别代表用户名 密码 服务器名
修改字符集
Sybase修改字符集(cp850 to cp936)
最重要的命令是:C:\\sybase\\charsets \\cp936>charset -Usa -Psybase -Sdiren binary.srt cp936
新中大软件字符集 转换为cp936技术说明
一、为什么要修改现在使用的数据库的字符集?
安装ASE数据库默认的字符集为CP850,其对 于中文的字符集(GB2312)比较少,很多汉字无法保存,导致在备份恢复时出错。
二、替换数据库字符集比较好的时间是什么时候? 建议在业务不繁忙进行该项工作。
三、确认修改数据库字符集的时间后,你的重要工作是什么? 注意:全部备份你的数据库,并且你要确保你的备份是有效的。
四、修改数据库字符集的整个思路是什么?
1、确认服务器停止 对外服务前,完整地备份你的数据库。
2、将原来cp850或iso-1字符集的数据库数据bcp out到你指定的文件目录下。 3、重新 构造你的服务器,配置你的服务器字符集为cp936。 4、重新建立并规划你的数据库。
5、将bcp out出来的数据bcp in 到新的数据库里(该数据库的字符集环境为cp936)。 6、修改并配合应用程序使其能够正常运行。确保对客户端最小化影响。
五、 修改的操作步骤
以下假设:
Sybase server 名:asesrv (在Dsedit中设置) Sybase sa的口令:sybase 生产库名:test
操作的目录:d:\\shen
建议:按照以上假设,只需要将所有的生产库名test替换成你的生产库名字!
1、停止数据库服务器对外服务,注意并不是停止你的服务器的 服务。检查一下master库的大小,不能小于40M。
2、备份你的数据库,注意是全部备份。建议你将你的数据库做一次DBCC。 1>dump database test to “d:\\shen\est.dmp” 2>go
3、生成批处 理文件
3.1 生成用户表BCP OUT批处理文件bcpout.bat
3.1.1 修改bcpout.txt文件,使其符合你的实际情况,bcpout.txt文件内容为:
select 'bcp test..' + name + ' out ' + '\"' + 'd:\\shen\\' + name + '.dat' + '\"' + ' -c -Usa -Psybase -Sasesrv' from sysobjects where type='U' order by name go
3.1.2 在DOS命令下执行以下命令:
? d:\\ren\\>isql -U sa -Psybase -Sasesrv -Dtest -ibcpout.txt -obcpout.bat
3.1.3 编辑结果文件bcpout.bat,将开头和结尾多余部分去掉,并查找到“GG_XTHP”,将该行删除(系统帮助表,因为包含有Text字段不能正常 bcp in/out)。
3.2 生成用户表BCP IN批处理文件bcpin.bat
3.2.1 修改bcpin.txt文件,使其符合你的实际情况,bcpin.txt文件内容为:
select 'bcp test..' + name + ' in ' + '\"' + 'd:\\shen\\' + name + '.dat' + '\"' + ' -c -Usa -Psybase -Sasesrv' from sysobjects where type='U' order by name go
3.2.2 在DOS命令下执行以下命令:
? d:\\ren\\>isql -U sa -Psybase -Sasesrv -Dtest -ibcpin.txt -obcpin.bat
3.2.3 编辑结果文件bcpin.bat,将开头和结尾多余部分去掉,并查找到“GG_XTHP”,将该行删除(系统帮助表,因为包含有Text字段不能正常 bcp in/out)。
4、导出数据
? 在DOS命令下执行4.1.3的结果文件bcpout.bat,得到数据。 ? d:\\shen\\>bcpout > bcpout_error.txt
? 导出结束后,检查输出文件bcpout_error.txt,看看有没有错误。
5、采用DBArtisan 7.2.1工具Extract以下文件,请严格按照以下顺序。
5.1 Check_Constraints.sql(导出后drop)
5.2 Foreign_keys.sql(导出后drop)
5.3 Indexes.sql(导出后drop)
5.4 Primary_Keys.sql (导出后drop),注意:可能出现FP_SNJZFP、SB_DZSBQKB不能drop,不必理会。
5.5 Procedures.sql
5.6 Triggers.sql(导出后drop)
5.7 Tables.sql
5.8 Views.sql
5.9 Sybase账号,导出可以参考以下命令:
? D:\\shen\\>bcp master..syslogins out syslogins.dat -c -Usa -Psybase -Sasesrv -F4
6、 在isql状态下查看原来数据库字符集使用情况,服务器和客户端的都要查看,方法是: ? 获得服务器端的字符集情况: ? 1>sp_helpsort ? 2>go
? 输出结果应为: Character Set = 2, cp850
Code Page 850 (Multilingual) character set. Sort order = 50, bin_cp850
Binary Sort order for Code Page 850 (cp850).
获得客户端字符集情况: 1>select @@client_csname 2>go
输出结果应为:iso_1
说明:很多时候应用程序报错,客户端和服务器端字符集不相匹配。
7、查看原来数据库设备使用情况(主要是起参考作用),并做详细记载: 1>sp_helpdb test 2>go
检查点:确认你的以上准备工作已经全部做好。
8、在 Sybase Central中将原来的生产数据库删除。
************************************************************** 经 过测试确认:数据库设备不需要删除,Sybase服务不需要重建!
注意:如果决定不重建Sybase服务,请直接跳过第9步直接到第10步! **************************************************************
9、 删除生产库设备,删除注册表相关键,重建Sybase服务。
9.1 删除生产库设备
9.2 停止Sybase服务,运行Sybase服务器配置工具,Remove Adaptive Server删除服务器diren,删除生产库物理文件,删除C:\\sybase\\data目录下文 件:master.dat,sybprocs.dat。
9.3 清理注册表信息(为了保证本次修改后的数据库服务器asesrv和原来的一样,将原来的相关服务器asesrv删除)。
\\\\HKEY_LOCAL_MACHINE\\SOFTWARE\\SYBASE\\Server\\DIREN \\\\HKEY_LOCAL_MACHINE\\SOFTWARE\\SYBASE\\Server\\DIREN_BS \\\\HKEY_LOCAL_MACHINE\\SOFTWARE\\SYBASE\\Server\\DIREN_HS \\\\HKEY_LOCAL_MACHINE\\SOFTWARE\\SYBASE\\Server\\DIREN_MS \\\\HKEY_LOCAL_MACHINE\\SYSTEM\\CurrentControlSet\\Control\\Session Manager\\Environment下相关键。
\\\\HKEY_LOCAL_MACHINE\\SYSTEM\\CurrentControlSet\\Services下以下键: SYBSQL_DIREN
?? SYBXPS_DIREN_XP ?? SYBBCK_DIREN_BS ?? SYBMON_DIREN_MS ?? SYBHIS_DIREN_HS
? ControlSet001以及ControlSet002等中的CurrentControlSet键中的相应键也要删除(如果有的话)。
9.4 运行Sybase服务器配置工具重新build server,使用原来数据库服务器名字。
9.5 重新设置服务器参数,调整master库大小,增加tempdb库大小。
10、将数据库的缺省字符集设置为cp936: C:\\>cd sybase
C:\\sybase>cd charsets
C:\\sybase\\charsets>cd cp936
C:\\sybase\\charsets\\cp936>charset -Usa -Psybase -Sasesrv binary.srt cp936
你将看到下面的信息,表示这时你已经成功添加了cp936字符集到你的系统中。 Loading file 'binary.srt'. Found a [sortorder] section. This is Class-1 sort order.
Finished loading the Character Set Definition. Finished loading file 'binary.srt'. 1 sort order loaded successfully
11、接着是将添加的 cp936设置为你的缺省值。方法是: C:\\sybase\\charsets\\cp936>isql -Usa -Psybase -Sasesrv 1> select name,id from syscharsets 2> go
ascii_8????????????????????????? 0 iso_1??????????????????????????? 1 cp850??????????????????????????? 2 bin_iso_1?????????????????????? 50 bin_cp850?????????????????????? 50 bin_cp936?????????????????????? 50 cp936????????????????????????? 171 这样知道你的cp936的ID号是171
12、将刚才新build的server的数据库缺省的字符集设置为cp936 ? 1> sp_configure 'default character set id',171 ? 2> go
? In changing the default sort order, you have also reconfigured SQL Server's default character set. ? Parameter Name???????????????? Default???? Memory Used Config Value Run Value ? ------------------------------ ----------- ----------- ------------ -----------
? default character set id???????????????? 1?????????? 0???????? 171??????????????? 2 ? (1 row affected)
? Configuration option changed. Since the option is static, Adaptive Server must? be rebooted in? order for the change to take effect. ? (return status = 0) 13、重新启动服务器两次(参考使用DOS命令net start SYBSQL_asesrv)。第一次启动报错“服务器SYBSQL_asesrv不能启动,请检查它的配置”很正常,第二次正确启动,表明你的设置成功 了。
14、在DOS下用edit修改客户端缺省字符集文件c:\\sybase\\locales\\locales.dat ? c:\\sybase\\locales\\>edit locales.dat
? 首先找到[NT]操作系统分组,然后定位到该分组最后一行“local = default, us_english, iso_1”,将其修改为:“local = default, us_english, cp936”。 ? 参考步骤6,确认服务器端和客户端字符集均已修改正确。
15、在Sybase Central中,重新建立新的空数据库,仔细规划好生产数据库数据设备和日志设备的大小。以前觉得数据库设备分配不合理的,在这时你可以重新考虑设备的 分配。
16、使用先前准备好的建库对象脚本建立表及其其他对象信息。将先前bcp出的数据bcp in到新的数据库中去,请严格按照如下顺序。索引在你数据导入完成后执行,效率会更高。
注意:生产库数据库选项“允许选择进入/批量复 制”、“缺省允许为空”要打勾;每做一步后,查看一下输出文件,看看有没有错误。
16.1 D:\\shen\\>isql -Usa -Psybase -Sasesrv -D test -i Tables.sql -o Tables_error.txt
16.2 D:\\shen\\>isql -Usa -Psybase -Sasesrv -D test -i Views.sql -o Views_error.txt
16.3 D:\\shen\\>bcpin > bcpin_error.txt
16.4 D:\\shen\\>isql -Usa -Psybase -Sasesrv -D test -i Primary_Keys.sql -o Primary_Keys_error.txt
16.5 D:\\shen\\>isql -Usa -Psybase -Sasesrv -D test -i Foreign_keys.sql -o Foreign_keys_error.txt
16.6 D:\\shen\\>isql -Usa -Psybase -Sasesrv -D test -i Indexes.sql -o Indexes_error.txt
16.7 D:\\shen\\>isql -Usa -Psybase -Sasesrv -D test -i Check_Constraints.sql -o Check_Con_error.txt
16.8 D:\\shen\\>isql -Usa -Psybase -Sasesrv -D test -i Procedures.sql -o Procedures_error.txt
16.9 D:\\shen\\>isql -Usa -Psybase -Sasesrv -D test -i Triggers.sql -o Triggers_error.txt
16.10 将logins bcp进入到系统表,保证原来的合法帐号被成功加入。注意:首先要设置/取消„allow updates to system tables‟。 ? D:\\shen\\> isql -Usa -Psybase -Sdiren
? 1> sp_configure \"allow updates to system tables\? 2>go
? 1> delete from syslogins where suid >=6????? //删除非SYBASE系统用户。 ? 2>go
? D:\\shen\\>bcp master..syslogins in syslogins.dat -c -Usa -Psybase -Sdiren
? D:\\shen\\> isql -Usa -Psybase -Sdiren
? 1> sp_configure \"allow updates to system tables\? 2>go
16.11 增加用户别名
16.11.1 修改syslogins.txt文件,使其符合你的实际情况,syslogins.txt文件内容为: use master go
select 'sp_addalias ' + name + ', dbo' + ' go'
from syslogins where suid>3 go
16.11.2 在DOS命令下执行以下命令:
? D:\\ren>isql -Usa -Psybase -isyslogins.txt -osysloginsalias.txt
16.11.3 编辑结果文件sysloginsalias.txt,将开头和结尾多余部分去掉。
16.11.4在DOS命令下执行以下命令(注意增加 了-Dtest):
? D:\\ren>isql -Usa -Psybase -Dtest -isysloginsalias.txt -osysloginsalias_error.txt
17、取消生产库数据库选项“允许选择进入/批量复制” 、“缺省允许为空”。
六、 客户端的修改
注:也可以设置好注册表信息后,生成一个文件,由各个操作员自己执行即可。
在DOS下用edit修改客户端缺省字符 集文件c:\\sybase\\locales\\locales.dat ? c:\\sybase\\locales\\>edit locales.dat
? 首先找到[NT]操作系统分组,然后定位到该分组最后一行“local = default, us_english, iso_1”,将其修改为:“local = default, us_english, cp936”。
6. 附:如何安装cp936字符集
以在Windows平台安装cp936字符集为例,说明如何 安装使用服务器中没有被默认安装的字符集。(在ASE 12.5.0.3版本中安装GB18030字符集的方法类似)
(这里SYBASE的安装路径为c:\\sybase)
1.c:\\>cd \\sybase\\charsets\\cp936
2.c:\\sybase\\charsets\\cp936> charset -Usa -Psa_pass -Sserver_name binary.srt cp936 3.在SQL环境中
1>select name,id from syscharsets 2>go
找到name为cp936对应的id(假设为171) 4.设置缺省字符集
1>sp_configure \"default character set id\2>go
5.重启server两次
(注:第一次启动后,server会自动宕掉,需要第二次重启后才能使用)
因篇幅问题不能全部显示,请点此查看更多更全内容