您的位置:首页 > 数据库

MSSQL数据库迁移

2009-07-07 16:19 239 查看
今天把一台服务器的数据转移到远程服务器上来,中间出现了一些问题,总的来说一路都解决,记录下。数据库是MSSQL2000的,需要把整个数据全部拷贝到远程服务器上,我选用的是完整备份和还原的方法,基本上不会有太大问题,但是中间出现过几个问题:
1 数据库无法还原,出现下面错误 --数据库恢复时出现“设备激活错误,请使用with move选项来标志该文件的有效位置”,解决方法:右键点“数据库”(注意不是某个特定的数据库)--》所有任务--》还原数据库--》选择“从设备”还原,选择要还原成的数据库名,然后在选项卡中,选择最现有数据库上强制还原数据库,然后在下面修改数据库还原后的物理路径,这个路径要是存在的一个路径,否则就会出现上面的错误,逻辑文件名可以不用改。

2 还原过来的数据库没有登录用户,需要重新建立登录用户,但是在建立的时候出现--- 错误21002:[SQL-DMO],这个时候需要删除每个数据库下的这个用户,然后企业管理器-> 安全性-> 登录-> 在右侧窗口中选择出问题的用户名-> 右击 属性-> 数据库访问// 选点要的数据库 *** -> 沟选下方 *** 的数据库角色 public 和 db_owner 完成。

3 在以上部门中可能会出现无法删除用户的情况,错误是--SQL SERVER 因为选定的用户拥有对象,所以无法除去该用户,这个时候可以使用以下的办法:
方法1>SQL SERVER 因为选定的用户拥有对象,所以无法除去该用户
对mssql出现选定的用户拥有对象而无法删除的处理
--将下面的代码在查询分析器中执行,修改库名
use 你的库名
go
declare tb cursor local
for
select 'sp_changeobjectowner '
+quotename(
+quotename(user_name(uid))
+'.'+quotename(name),'''')
+',''dbo'''
from sysobjects
where objectproperty(id,N'isusertable')=1
and uid<>user_id('dbo')
declare @s nvarchar(4000)
open tb
fetch tb into @s
while @@fetch_status=0
begin
exec(@s)
fetch tb into @s
end
close tb
deallocate tb

方法2>sql2000 因为选定的用户拥有对象,所以无法除去该用户
由于mssql200数据库的错误,我把一个原来的数据库还原到现在的sql上,此时我来到用户里面,想把还原过来的用户删除掉,结果却提示“ 因为选定的用户拥有对象,所以无法除去该用户 ”:



删除不了,我就准备把系统里的该用户添加到这个数据库上来看看可以不,却又提示这么一个错误(microsoft sql-dmo 窗口):
错误21002:[SQL-DMO]用户"liuhui"已经存在。



因为业务要求,我又不能重新建立一个用户给它或换一个用户,该数据库只能被该用户使用,标准的规范的服务器格式不能打破,要不会带来以后维护的超级麻烦,没办法求救google 和 baidu ,结果无所不知的他们让我失望了,没办法,只好请求一个经验丰富的朋友帮忙,问题解决了,该技术为不传之密,一般人我不告诉他:
1.打开企业管理器,展开服务器,右键点击本地服器,属性



打开sql server 属性(配置)窗口
2.选择常规窗口,将 自动开启sql server 代理 选上:



确定
3.重复动作1.打开打开sql server 属性(配置)窗口,选择 服务器设置窗口:



允许对系统目录直接进行修改 选上,确定。
4.展开数据库,看到数据库系统表 sysusers ,右键--打开表--返回所有行



5.选择应为还原而添加进来的用户,找到相关行,点右键 删除






选择
在返回到用户列表,看看还有该用户没有,如果没有用户,我们在去sql的安全里面把该数据库对应的用户添加上去,我把liuhui添加上去了,测试网站没有问题了。
再返回动作3把选择上的 允许对系统目录直接进行修改 去掉
使用下面这个方法也可以删除这个用户,把数据表里的所有者对象全部修改成dbo先在,现在在删除就已经没有问题了,本文出自 “流星 ” 博客,请务必保留此出处http://lsscto.blog.51cto.com/779396/174946
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: