http://expert.csdn.net/Expert/topic/1760/1760796.xml?temp=.7696955
孤立用户问题-----    孤立用户 
把数据库备份还原到另一个服务器时,可能会遇到孤立用户的问题。下面的方案显示并解决了这个问题: 通过执行 sp_addlogin,把登录 janetl 改名为 dbo。 
sp_addlogin 'janetl', 'dbo'备份数据库。在本例中,备份 Northwind。 
BACKUP DATABASE Northwind
TO DISK = 'c:\mssql\backup\northwnd'除去刚刚备份的数据库。 
DROP DATABASE Northwind除去登录。 
sp_droplogin 'janetl'还原备份的数据库。 
RESTORE DATABASE Northwind
FROM DISK = 'c:\mssql\backup\northwnd'select * from sysusersjanetl 登录不能访问 Northwind 数据库,除非允许 guest 登录。尽管 janetl 登录已经删除,它仍然(作为一个孤立行)显示在 sysusers 表中:USE Northwind
SELECT *
FROM sysusers
WHERE name = 'janetl'解决孤立用户问题 用 sp_addlogin 添加一个临时登录。为孤立用户指定安全标识符 (SID)(从 sysusers)。 
sp_addlogin @loginame = 'nancyd',
    @sid = 0x32C864A70427D211B4DD00104B9E8A00用 sp_dropalias 除去属于别名 SID 的临时别名。 
sp_dropalias 'nancyd'用 sp_dropuser 除去原始用户(即现在的孤立用户)。 
sp_dropuser 'janetl'用 sp_dropuser 除去原始登录。 
sp_droplogin 'nancyd'

解决方案 »

  1.   

    孤立用户疑难解答
    把数据库备份还原到另一个服务器时,可能会遇到孤立用户的问题。下面的方案显示并解决了这个问题: 通过执行 sp_addlogin,把登录 janetl 改名为 dbo。 
    sp_addlogin 'janetl', 'dbo'备份数据库。在本例中,备份 Northwind。 
    BACKUP DATABASE Northwind
    TO DISK = 'c:\mssql\backup\northwnd'除去刚刚备份的数据库。 
    DROP DATABASE Northwind除去登录。 
    sp_droplogin 'janetl'还原备份的数据库。 
    RESTORE DATABASE Northwind
    FROM DISK = 'c:\mssql\backup\northwnd'janetl 登录不能访问 Northwind 数据库,除非允许 guest 登录。尽管 janetl 登录已经删除,它仍然(作为一个孤立行)显示在 sysusers 表中:USE Northwind
    SELECT *
    FROM sysusers
    WHERE name = 'janetl'解决孤立用户问题 用 sp_addlogin 添加一个临时登录。为孤立用户指定安全标识符 (SID)(从 sysusers)。 
    sp_addlogin @loginame = 'nancyd',
        @sid = 0x32C864A70427D211B4DD00104B9E8A00用 sp_dropalias 除去属于别名 SID 的临时别名。 
    sp_dropalias 'nancyd'用 sp_dropuser 除去原始用户(即现在的孤立用户)。 
    sp_dropuser 'janetl'用 sp_dropuser 除去原始登录。 
    sp_droplogin 'nancyd'
      

  2.   

    用户问题
        原因是这样的,是你备份的数据库中有此用户,但是你现在的sqlserver没有这个用户,一种方法是你在恢复好的数据库中把该用户删掉,请查找不同的角色是否对应有次此用户。另一种方法是在sqlserver中先创建此用户,然后再恢复。显然第一种方法很简单。但如果如果该用户对应了自己的对象,你讲无法删除,这样就要你先把它对应的对象更改所有者。
    在 SQL Server 中创建一个用户的步骤是:首先创建该用户的 Login ,这个信息保存在 Master 数据库的 sysxlogins 表中。然后创建该用户在具体数据库中的 User ,这个信息保存在具体的数据库的 sysusers 表中附加的数据库中包含的仅仅是 Users ,但并没有提供 Master 数据库 sysxlogins 表中需要同时存在的 login 数据,所以,这些附加上来的用户实际上成了 orphan 用户。你需要把原服务器中 master 数据库中 sysxlogins 表中相应记录也转移过来,否则,只有删除这些 User 重新建立
      

  3.   

    try:
    exec sp_changeobjectowner Yourdatabase,dbo
      

  4.   

    给用户分配系统sysAdmin角色,肯定可以访问了.:)