SQL Server数据库中还原孤立用户的方法集合

SQL Server数据库中还原孤立用户的方法集合

虽然SQL Server现在搬迁的技术越来越多,自带的方法也越来越高级。

但是我们的SQL Server在搬迁的会出现很多孤立用户,微软没有自动的处理。

因为我们的数据库权限表都不会在应用数据库中,但是每次对数据库作迁移的时候,单个数据库却带着它的数据库用户对象。

并且我们在新的数据库机器上也不能登录这些账号,但是它却静悄悄的存在我们的数据库中。

微软以前提供的一个老的接口存储过程来处理这个问题。

sp_change_users_login

将现有数据库用户映射到 SQL Server 登录名。后续版本的 Microsoft SQL Server 将删除该功能。请避免在新的开发工作中使用该功能,并着手修改当前还在使用该功能的应用程序。 请改用 ALTER USER。

虽然每次都在说以后的版本会不支持,但是用了好几个版本还是支持的。

语法:

sp_change_users_login [ @Action = ] ‘action‘
    [ , [ @UserNamePattern = ] ‘user‘ ]
    [ , [ @LoginName = ] ‘login‘ ]
    [ , [ @Password = ] ‘password‘ ]
[;]

参数:

[ @Action = ] ‘action

说明过程要执行的操作。action 的数据类型为 varchar(10)action 可具有下列值之一。



说明


Auto_Fix


将当前数据库的 sys.database_principals 系统目录视图中的用户项链接到同名的 SQL Server 登录名。如果不存在同名的登录名,将会创建一个。检查Auto_Fix 语句的结果,确认实际链接是否正确。在对安全性较为敏感的情况下,要避免使用Auto_Fix

如果使用 Auto_Fix 时登录名尚不存在,则必须指定 user 和 password,否则必须指定user,但password 将被忽略。login 必须为 NULL。user 必须是当前数据库中的有效用户。不能将另一个用户映射到该登录名。


Report


列出当前数据库中未链接到任何登录名的用户以及相应的安全标识符 (SID)。userlogin 和 password 必须为 NULL 或不指定。


Update_One


将当前数据库中的指定 user 链接到现有 SQL Server login。必须指定 user和 loginpassword 必须为 NULL 或不指定。

[ @UserNamePattern = ] ‘user

当前数据库中的用户名。user 的数据类型为 sysname,默认值为 NULL。

[ @LoginName = ] ‘login

SQL Server 登录的名称。login 的数据类型为 sysname,默认值为 NULL。

[ @Password = ] ‘password

通过指定 Auto_Fix 创建的新 SQL Server 登录名分配的密码。如果已存在匹配的登录名,则映射该用户名与登录名且忽略password。如果不存在匹配的登录名,则 sp_change_users_login 创建新的 SQL Server 登录名并分配password作为新登录名的密码。password 的数据类型为 sysname,且不能为 NULL。

返回代码值:

0(成功)或 1(失败)

结果集:

列名 数据类型 说明

UserName


sysname


数据库用户名。


UserSID


varbinary(85)


用户的安全标识符。

注释:

使用 sp_change_users_login 将当前数据库中的数据库用户链接到 SQL Server 登录名。如果用户登录名已更改,则使用 sp_change_users_login 将用户链接到新的登录,而不会丢失用户的权限。新的login 不能为 sa,而user不能为 dbo、guest 或 INFORMATION_SCHEMA 用户。

sp_change_users_login 不能用于将数据库用户映射到 Windows 级主体、证书或非对称密钥。

sp_change_users_login 不能与通过 Windows 主体创建的 SQL Server 登录名一起使用,也不能与使用 CREATE USER WITHOUT LOGIN 创建的用户一起使用。

不能在用户定义的事务中执行 sp_change_users_login。

权限:

需要 db_owner 固定数据库角色的成员身份。只有 sysadmin 固定服务器角色的成员才能指定 Auto_Fix 选项。

示例:

A. 显示登录映射的当前用户的报告

下例生成当前数据库中的用户及其安全标识符 (SID) 的报告。

  复制代码
EXEC sp_change_users_login ‘Report‘;

B. 将数据库用户映射到新的 SQL Server 登录名

在以下示例中,数据库用户与新的 SQL Server 登录名关联。数据库用户 MB-Sales 首先映射到另一个登录名,然后重新映射到登录名MaryB。

  复制代码
--Create the new login.
CREATE LOGIN MaryB WITH PASSWORD = ‘982734snfdHHkjj3‘;
GO
--Map database user MB-Sales to login MaryB.
USE AdventureWorks2008R2;
GO
EXEC sp_change_users_login ‘Update_One‘, ‘MB-Sales‘, ‘MaryB‘;
GO

C. 自动将用户映射到登录名(必要时新建一个登录名)

以下示例显示如何使用 Auto_Fix 将现有用户映射到同名的登录名,以及如何在不存在登录名 Mary 的情况下,创建密码为B3r12-3x$098f6 的 SQL Server 登录名Mary。

实战:

    /*很多做DBA的朋友也許都会碰到一个这样的问题,
    在数据还原到其他服务器时,登录名会丢失,重建非常麻烦,
    特別是数据库用户较多的的情况,其实这个问题解决非常简单,
    sql server 2005 及以前的产品,
    sql server 提供了 sp_change_users_login存储过程,(sql server 2008 须用ALTER USER)
    sp_change_users_login有三种动作:report,update_one和auto_fix
    具体用法:*/
/*1.列出当前数据库中的孤立用戶*/
    exec  sp_change_users_login ‘report‘
/*2.如果已有登录用戶,将用戶名映射为指定的登录名*/
    exec sp_change_users_login ‘UPDATE_ONE‘,‘用戶名‘,‘登录名‘  ----最常用
    or
    exec sp_change_users_login ‘AUTO_FIX‘,‘用戶名‘
/*3.如果沒有建立登录用戶*/
    exec sp_change_users_login ‘Auto_Fix‘, ‘登录名‘, NULL, ‘登录密码‘
/*--相同名字可以使用,处理孤立用户
--在单个数据库上执行*/
    exec sp_change_users_login ‘AUTO_FIX‘,‘db_writer‘
    exec sp_change_users_login ‘AUTO_FIX‘,‘db_reader‘
时间: 2024-10-03 18:22:54

SQL Server数据库中还原孤立用户的方法集合的相关文章

清空SQL Server数据库中所有表数据的方法

其实删除数据库中数据的方法并不复杂,为什么我还要多此一举呢,一是我这里介绍的是删除数据库的所有数据,因为数据之间可能形成相互约束关系,删除操作可能陷入死循环,二是这里使用了微软未正式公开的sp_MSForEachTable存储过程. 也许很多读者朋友都经历过这样的事情:要在开发数据库基础上清理一个空库,但由于对数据库结构缺乏整体了解,在删除一个表的记录时,删除不了,因为可能有外键约束,一个常见的数据库结构是一个主表,一个子表,这种情况下一般都得先删除子表记录,再删除主表记录. 说道删除数据记录,

查询sql server数据库中字段内容长度的方法

在做项目的时候,需要查询数据库中相应字段的内容长度,以下是记录下来的方法: SELECT length = DATALENGTH(username),   username FROM TABLENAME ORDER BY length desc

在SQL SERVER 2005中还原数据库时出现错误:system.data.sqlclient.sqlerror 媒体集有 2 个媒体簇 但只提供了 1 个。必须提供所有成员。 (microsoft.sqlserver.smo)

问题:在SQL SERVER 2005中还原数据库时出现错误:system.data.sqlclient.sqlerror 媒体集有 2 个媒体簇 但只提供了 1 个.必须提供所有成员. (microsoft.sqlserver.smo) 原因:由于备份时,没有去掉默认的备份路径(C:\Program Files\Microsoft SQL Server\MSSQL.1\MSSQL\Backup\backup.bak),而又添加了一个新的路径,结果备份了两份,但它们之间彼此依赖,所以没有办法恢复

SQL server数据库中的DateTime类型出现的问题

我们知道这个SQL server数据库中的DateTime类型是数据库应用开发中经常用到的一种数据类型,而C#语言中也有DateTime类型,虽然二者都是用来描述时间的,但是它们的默认值是不同的,这点必须注意,在开发过程中,二者之间相互适应关系处理不当,可能会产生不必要的麻烦,就等于浪费时间,所以记住.举个例子看看: 创建一个windows应用程序,创建一个用户信息实体类UserInfo.代码如下: 注意的是:用户信息类中的“操作日期”属性是日期类型. 再创建一个业务操作类,UserInfoOp

转:SQL SERVER数据库中实现快速的数据提取和数据分页

探讨如何在有着1000万条数据的MS SQL SERVER数据库中实现快速的数据提取和数据分页.以下代码说明了我们实例中数据库的“红头文件”一表的部分数据结构: CREATE TABLE [dbo].[TGongwen] (    --TGongwen是红头文件表名 [Gid] [int] IDENTITY (1, 1) NOT NULL , --本表的id号,也是主键 [title] [varchar] (80) COLLATE Chinese_PRC_CI_AS NULL ,  --红头文件

C#从SQL server数据库中读取l图片和存入图片

原文:C#从SQL server数据库中读取l图片和存入图片 本实例主要介绍如何将图片存入数据库.将图片存入数据库,首先要在数据库中建立一张表,将存储图片的字段类型设为Image类型,用FileStream类.BinaryReader把图片读成字节的形式,赋给一个字节数组,然后用ADO.SqlCommand对象的ExecuteNonQuery()方法来把数据保存到数据库中.主要代码如下: private void button1_Click(object sender, EventArgs e)

SQL server数据库备份还原问题备忘(亲测有效)

问题一:SQL server数据库备份还原方法 http://www.cnblogs.com/zgqys1980/archive/2012/07/04/2576382.html 问题二:无法执行 BACKUP LOG,因为当前没有数据库备份 http://blog.csdn.net/aojiancc2/article/details/46316451 问题三:还原数据库失败 备份集中数据库备份与现有数据库不同 http://jingyan.baidu.com/article/fb48e8be52

sql server数据库中索引失效的问题讨论

有关于数据库中索引失效的问题,网上也有相关的讨论.不过他们是针对oracle数据库进行讨论的.那么在sql server数据库中索引什么时候 会失效呢.总结了一下,不过我没有经过测试.没测试就没有发言权,这里仅供自己参考. 首先,所谓失效.并不真的就是这个索引被删除了.而是在这些情况下,DBMS不会检索索引列表了.执行速度和没有这个索引时的速度一样. 但是再执行另外的一条语句.同样索引可以正常起作用.所以索引的失效是针对某条sql语句的,而不是针对索引本身的.那么在哪些情况下, 确切的说是在哪类

浅析SQL Server数据库中的伪列以及伪列的含义

SQL Server中的伪列 下午看QQ群有人在讨论(非聚集)索引的存储,说,对于聚集索引表,非聚集索引存储的是索引键值+聚集索引键值:对于非聚集索引表,索引存储的是索引键值+RowId,这应该是一个常识,对此不作具体详细阐述.这里主要是提到的RowId引起了一点思考.那么,这个RowId是个什么玩意?能不能更加直观一点来看看RowId的信息?代表什么含义?这个当然也是可以的.Oracle中的表中有一个伪列的概念,就是在查询表的时候加上select rowid,* from Table,会查询出