登录  
 加关注
查看详情
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

糟老頭的地盤

老頭的地盤听老頭的

 
 
 

日志

 
 

数据库还原后无法登陆的问题?因为选定的用户拥有对象,无法删除  

2010-09-21 20:56:25|  分类: study |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |

针对服务器托管和服务器租用的用户在重新做系统之后,SQL2000数据库加载完原库后,无法使用原先的用户权限,一般是因为原数据库里的用户与新建的登录用户不一致造成的(即便是两者用户名和密码一样也不行,因为两者的 ID 不一样。sqlserver 是根据这个 ID 来识别的)


谓孤立帐户,就是某个数据库的帐户只有用户名而没有登录名,这样的用户在用户库的sysusers系统表中存在,而在master数据库的syslogins中却没有对应的记录。

孤立帐户的产生一般是一下两种:
1.将备份的数据库在其它机器上还原;
2.重装系统或SQL SERVER之后只还原了用户库

解决方法是使用sp_change_users_login来修复。

sp_change_users_login的用法有三种

用法1:
exec sp_change_users_login 'REPORT'

列出当前数据库的孤立用户

用法2:
exec sp_change_users_login 'AUTO_FIX','用户名'

可以自动将用户名所对应的同名登录添加到syslogins中

用法3:
exec sp_change_users_login 'UPDATE_ONE','用户名','登录名'
将用户名映射为指定的登录名。

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先在,现在在删除就已经没有问题了,
==================================================


问题解决方式:
      1 如果是一张表有此问题,解决方式如下:
      
       exec sp_changeobjectowner mis.tablename', 'dbo'
    
       这样就把tablename指定的表的所有者赋值给了dbo用户

     2 如果所有表都存在此问题,这是就要编写存储过程实现批量修改了
      
         IF OBJECT_ID('ChangeAll') IS NOT NULL DROP PROC ChangeAll
         GO      CREATE PROCEDURE ChangeAll (
             @old sysname,
             @new sysname
         )
        AS
             DECLARE @objname sysname    SET NOCOUNT ON              IF USER_ID(@old) IS NULL
                BEGIN
                    RAISERROR ('The @old passed does not exist in the database', 16, 1)
                    RETURN
                END
             IF USER_ID(@new) IS NULL
                BEGIN
                    RAISERROR ('The @new passed does not exist in the database', 16, 1)
                    RETURN
                END 

            DECLARE owner_cursor CURSOR FOR

             SELECT name FROM sysobjects WHERE uid = USER_ID(@old)
             OPEN owner_cursor
             FETCH NEXT FROM owner_cursor INTO @objname
             WHILE (@@fetch_status <> -1)
                 BEGIN
                     SET @objname = @old + '.' + @objname
                     EXEC sp_changeobjectowner @objname, @new
                     FETCH NEXT FROM owner_cursor INTO @objname
                 END </DIV><DIV>            CLOSE owner_cursor
        &nbsp;   DEALLOCATE owner_cursor
            GO

          EXEC ChangeAll @old = 'mis', @new = 'dbo'这样就完成了批量修改权限的工作

 

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/fzzsh/archive/2010/03/08/5356567.aspx

  评论这张
 
阅读(1614)| 评论(0)

历史上的今天

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2018