【参加讨论】 在win2000 server & professional不能attach db file的原因和解决方法。
yy的sql server因为master db损坏,在没有backup的情况下,无法修复和restore,无奈只能reinstall sql server,然后用sp_attach_db来附加原来的应用db file(xxx.mdf and xxx.ldf)。
为了保险起见,准备现在一台双平台的电脑上面试验。这台电脑c:\为简体中文win98,然后从win98安装了简体中文win2000 server到d:\
在中文win2000下,以default方式安装了sql server english standard edition,restarting computer,一切正常。
进入programs \ microsoft sql server 7.0 \ query analyzer,在master db中执行如下命令:
exec sp_attach_db ‘xxx’, ‘d:\mssql7\data\xxx_data.mdf’, ‘d:\mssql7\data\xxx_log.ldf’
随即出现错误提示:
server: msg 1816, level 16, state 1, line 1
could not attach the database because the character set, sort order, or unicode collation for the database differs from this server.
server: msg 1816, level 16, state 1, line 1
could not attach the database because the character set, sort order, or unicode collation for the database differs from this server.
warning: sort order 52 in database differs from server sort order of 199.
warning: unicode language locale 1033 in database differs from server unicode language locale of 2052.
warning: sort
错误信息指出:因为字符集设置、排序或者unicode collation和本服务器不一致,所以无法附加数据库。
ms sql server 安装时如果选择default安装的话,default字符集是chinese,考虑可能是这里的问题,yy为此再次uninstall sql server,并且在install的时候选手动设置了字符集为iso charact set, sort order为dictionary order, case-insensitive, unicode collation为general.
安装完毕再次执行sp_attach_db,仍然提示出错,错误仍然不变。
这下百思不得其解,多方询问朋友仍然不能解决。突然想到,是不是因为从中文98种安装win2000致使win2000的字符集无法和sql server以致呢?虽然不能肯定是这样,但是抱着试试看的一丝希望在一台直接安装win2000的机器上重复上述步骤,完全成功。然后再返回出错的机,从dos reinstall win2000,删除以前的win2000, 重复上述步骤,也完全成功。
证明问题出在从中文win98升级或者安装的win2000字符集将和英文sql server和其下建立的db不一致,相信除了不能attach db外,可能应用的时候还会出现其他问题。
相信朋友们很少有象我这样恢复数据库的,也不大可能遇上这个问题,但是我还是愿意写出来给大家参考。至于产生这个问题的更深层的原因,我现在也不大清楚,如果哪位朋友知道,请帖出来,ok?呵呵
作者:yy e-mail: webmaster@possehl.com.cn or xb_yuan@eb-it.com