zoukankan      html  css  js  c++  java
  • SqlServer2000孤立用户解决方案

     当数据库从一个地方还原到另一个地方时会出现孤立用户问题。孤立用户简单来说就是在原来数据库上的用户到了新的数据库中就找不到登录用户了。即使你建一个一模一样的登录用户,也没法与旧的用户对应上,因为sqlserver中用户是通过SID去标识一个用户的,而不是用户名。这时如果你想删掉旧用户也是办不到的,因为旧用户会占有一些对象,例如表,存储过程等,这些东西令你无法删掉它。

        因此我们应该先想办法把旧用户给干掉。先在要操作的数据库中建立如下存储过程,代码如下:


    Create PROCEDURE ChangeAllObjOwner (
    @oldowner sysname,
    @newowner sysname
    )
    AS
    DECLARE @objname sysname
    SET NOCOUNT ON

    --检查旧用户是否存在
    IF USER_ID(@oldowner) IS NULL
    BEGIN
    RAISERROR ('The @oldowner passed does not exist in the database', 16, 1)
    RETURN
    END
    --检查新用户是否存在
    IF USER_ID(@newowner) IS NULL
    BEGIN
    RAISERROR ('The @newowner passed does not exist in the database', 16, 1)
    RETURN
    END

    DECLARE owner_cursor CURSOR FOR
    Select name FROM sysobjects Where uid = USER_ID(@oldowner)

    OPEN owner_cursor
    FETCH NEXT FROM owner_cursor INTO @objname
    WHILE (@@fetch_status <> -1)
    BEGIN
    SET @objname = @oldowner + '.' + @objname
    EXEC sp_changeobjectowner @objname, @newowner
    FETCH NEXT FROM owner_cursor INTO @objname
    END

    CLOSE owner_cursor
    DEALLOCATE owner_cursor

    GO

    然后转到查询分析器,执行以上存储过程:

    exec ChangeAllObjOwner 'olduser','dbo'

         建议把对象都转成是dbo的,也就是sa帐号下的,这时候就可以删除旧用户了。然后再建一个新的登录用户,对应回数据库,然后可以再执行一次上述的存储过程,把数据sa的对象转给新用户。

          在转移对象时会有一定的风险,但这种风险还是可以接受的,至少我到目前为止也没遇到对象被损坏的情况,大家不妨试试。


    <本文系转载自:http://gdnpc.w247.dns911.cn/article.asp?id=21
  • 相关阅读:
    关于如何实现接口IComparer以实现自己需要的排序规则
    随机移动
    关于资源版本管理的问题
    Unity3D内部脚本编程入门
    删除GameObject上除了Quality子物体之外其他子物体的组件(但不删除transform)
    资料
    c# 基础知识点
    c# 匿名方法(委托)
    git
    一篇关于Unity3D优化的文章,翻译脚本优化部分
  • 原文地址:https://www.cnblogs.com/sygwin/p/2182016.html
Copyright © 2011-2022 走看看