您的位置:首页 > 数据库

数据库2000迁移到2005遇到的问题

2010-04-19 11:24 281 查看
数据库2000迁移到2005遇到的问题

一、SQL Server 2005“备份集中的数据库备份与现有的数据库不同”

还原数据库的时候可能会遇到这个问题,在勾选了“选项”->“覆盖现有数据库”就可以解决。

二、SQl Server2005目录查找失败,出现操作系统错误..

在还原数据库的时候在bak文件中存储了原始数据库的存储路径,这个路径在新数据库所在机器上不存在,就发生这个错误,所以还原的时候需要更改一下mdf文件和ldf文件的位置。
方法步骤:
1、在SQL 2005 新建一个同名数据库,保存于:
C:/Program Files/Microsoft SQL Server/MSSQL/data/
2、在查询分析器中执行以下语句:
RESTORE DATABASE AcafaDb FROM DISK = 'C:/AcafaDb.bak' with replace, MOVE 'AcafaDb_Data' TO 'C:/Program Files/Microsoft SQL Server/MSSQL/Data/AcafaDb_Data.MDF', MOVE 'AcafaDb_log' TO 'C:/Program Files/Microsoft SQL Server/MSSQL/Data/AcafaDb_Log.LDF'

注意:这里的 AcafaDb 是我数据库的名称。

3、成功还原后,数据库里的用户变成了孤立帐户。
所谓孤立帐户,就是某个数据库的帐户只有用户名而没有登录名,这样的用户在用户库的sysusers系统表中存在,而在master数据库的syslogins中却没有对应的记录。
孤立帐户的产生一般是一下两种:
1.将备份的数据库在其它机器上还原;
2.重装系统或SQL SERVER之后只还原了用户库
解决方法是使用系统自带过程sp_change_users_login来修复:
USE AcafaDb;
GO
EXEC sp_change_users_login 'Auto_Fix', 'acafacom', NULL, 'password';
GO

意思是:把用户名“acafacom”修复,密码为“password”

查询孤立用户语句:
EXEC sp_change_users_login 'Report'
更多请参考: http://msdn.microsoft.com/pt-br/library/ms174378.aspx
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: