繁体中文
设为首页
加入收藏
当前位置:网络编程首页 >> Mssql >> 在SQL Server实例之间传输登录和密码

在SQL Server实例之间传输登录和密码

2007-07-16 04:25:07  作者:  来源:  浏览次数:903  文字大小:【】【】【

概要

在将数据库移动到新服务器后,用户可能无法登录到新服务器。相反,他们会收到下面的错误消息:

Msg 18456, Level 16, State 1

Login failed for user '%ls'.

您必须将登录和密码传输到新服务器。本文介绍如何将登录和密码传输到新服务器。

如何在运行 SQL Server 7.0 的服务器之间传输登录和密码

SQL Server 7.0 数据转换服务 (DTS) 对象传输功能可在两台服务器之间传输登录和用户,但它不传输 SQL Server 验证登录的密码。要将登录和密码从一台运行 SQL Server 7.0 的服务器传输到另一台运行 SQL Server 7.0 的服务器,请执行“在不同版本的 SQL Server 之间传输登录和密码的完整解决方案”一节中的步骤。

如何从 SQL Server 7.0 向 SQL Server 2000 或者在运行 SQL Server 2000 的服务器之间传输登录和密码

要从 SQL Server 7.0 服务器向 SQL Server 2000 的一个实例或者在 SQL Server 2000 的两个实例之间传输登录和密码,可以使用 SQL Server 2000 中新的 DTS 包传输登录任务。为此,请按照下列步骤操作:1. 连接到 SQL Server 2000 目标服务器,移动到 SQL Server 企业管理器中的数据转换服务,展开此文件夹,右键单击“本地包”,然后单击“新增包”。

1、在 DTS 程序包设计器打开后,单击“任务”菜单上的“传输登录任务”。根据需要完成有关“源”、“目标”和“登录”选项卡的信息。

重要说明:SQL Server 2000 目标服务器不能运行 64 位版本的 SQL Server 2000。64 位版本 SQL Server 2000 的 DTS 组件不可用。如果要从其他计算机上的 SQL Server 实例中导入登录,您的 SQL Server 实例必须在域帐户下运行才能完成此任务。

注意:DTS 方法将传输密码,但不会传输原始 SID。如果登录不是使用原始 SID 创建的,而且用户数据库也被传输到一台新服务器,则该数据库用户将从该登录中孤立出去。要传输原始 SID 并绕过被孤立的用户,请执行“在不同版本的 SQL Server 之间传输登录和密码的完整解决方案”一节中的步骤。

在不同版本的 SQL Server 之间传输登录和密码的完整解决方案

此方法适用于以下情况:

 ull; 从 SQL Server 7.0 向 SQL Server 7.0 传输登录和密码。

 ull; 从 SQL Server 7.0 向 SQL Server 2000 传输登录和密码。

 ull; 从 SQL Server 7.0 向 SQL Server 2005 传输登录和密码。

 ull; 在运行 SQL Server 2000 的服务器之间传输登录和密码。

 ull; 从 SQL Server 2000 向 SQL Server 2005 传输登录和密码。

注意:请查看本文末尾的备注,以了解有关下列步骤的重要信息。

要在不同版本的 SQL Server 之间传输登录和密码,请按下列步骤操作:1. 在源 SQL Server 上运行以下脚本。此脚本可在 master 数据库中创建名为  _hexadecimal 和  _help_revlogin 的两个存储过程。请在完成过程的创建之后继续执行第 2 步。

注意:下面的过程取决于 SQL Server 系统表。这些表的结构在 SQL Server 的不同版本之间可能会有变化,请不要直接从系统表中选择。

----- Begin Script, Create  _help_revlogin procedure -----
  USE master
  GO
  IF OBJECT_ID (' _hexadecimal') IS NOT NULL
  DROP PROCEDURE  _hexadecimal
  GO
  CREATE PROCEDURE  _hexadecimal
  @binvalue varbinary(256),
  @hexvalue varchar(256) OUTPUT
  AS
  DECLARE @charvalue varchar(256)
  DECLARE @i int
  DECLARE @length int
  DECLARE @hexstring char(16)
  SELECT @charvalue = '0x'
  SELECT @i = 1
  SELECT @length = DATALENGTH (@binvalue)
  SELECT @hexstring = '0123456789ABCDEF'
  WHILE (@i <= @length)
  BEGIN
  DECLARE @tempint int
  DECLARE @firstint int
  DECLARE @secondint int
  SELECT @tempint = CONVERT(int, SU TRING(@binvalue,@i,1))
  SELECT @firstint = FLOOR(@tempint/16)
  SELECT @secondint = @tempint - (@firstint*16)
  SELECT @charvalue = @charvalue +
  SU TRING(@hexstring, @firstint+1, 1) +
  SU TRING(@hexstring, @secondint+1, 1)
  SELECT @i = @i + 1
  END
  SELECT @hexvalue = @charvalue
  GO
  IF OBJECT_ID (' _help_revlogin') IS NOT NULL
  DROP PROCEDURE  _help_revlogin
  GO
  CREATE PROCEDURE  _help_revlogin @login_name sy ame = NULL AS
  DECLARE @name  sy ame
  DECLARE @xstatus int
  DECLARE @bi wd  varbinary (256)
  DECLARE @txtpwd  sy ame
  DECLARE @tm tr  varchar (256)
  DECLARE @SID_varbinary varbinary(85)
  DECLARE @SID_string varchar(256)
  IF (@login_name IS NULL)
  DECLARE login_curs CURSOR FOR
  SELECT sid, name, xstatus, pa word FROM master..sysxlogi 
  WHERE srvid IS NULL AND name < gt; 'sa'
  ELSE
  DECLARE login_curs CURSOR FOR
  SELECT sid, name, xstatus, pa word FROM master..sysxlogi 
  WHERE srvid IS NULL AND name = @login_name
  OPEN login_curs
  FETCH NEXT FROM login_curs INTO @SID_varbinary, @name, @xstatus, @bi wd
  IF (@@fetch_status = -1)
  BEGIN
  PRINT 'No login(s) found.'
  CLOSE login_curs
  DEALLOCATE login_curs
  RETURN -1
  END
  SET @tm tr = '/*  _help_revlogin script '
  PRINT @tm tr
  SET @tm tr = '** Generated '
  + CONVERT (varchar, GETDATE()) + ' on ' + @@SERVERNAME + ' */'
  PRINT @tm tr
  PRINT '
  PRINT 'DECLARE @pwd sy ame'
  WHILE (@@fetch_status < gt; -1)
  BEGIN
  IF (@@fetch_status < gt; -2)
  BEGIN
  PRINT '
  SET @tm tr = '-- Login: ' + @name
  PRINT @tm tr
  IF (@xstatus &am  4) = 4
  BEGIN -- NT authenticated account/group
  IF (@xstatus &am  1) = 1
  BEGIN -- NT login is denied acce 
  SET @tm tr = 'EXEC master.. _denylogin '' + @name + ''
  PRINT @tm tr
  END
  ELSE BEGIN -- NT login has acce 
  SET @tm tr = 'EXEC master.. _grantlogin '' + @name + ''
  PRINT @tm tr
  END
  END
  ELSE BEGIN -- SQL Server authentication
  IF (@bi wd IS NOT NULL)
  BEGIN -- Non-null pa word
  EXEC  _hexadecimal @bi wd, @txtpwd OUT
  IF (@xstatus &am  2048) = 2048
  SET @tm tr = 'SET @pwd = CONVERT (varchar(256), ' + @txtpwd + ')'
  ELSE
  SET @tm tr = 'SET @pwd = CONVERT (varbinary(256), ' + @txtpwd + ')'
  PRINT @tm tr
  EXEC  _hexadecimal @SID_varbinary,@SID_string OUT
  SET @tm tr = 'EXEC master.. _addlogin '' + @name
  + '', @pwd, @sid = ' + @SID_string + ', @encryptopt = '
  END
  ELSE BEGIN
  -- Null pa word
  EXEC  _hexadecimal @SID_varbinary,@SID_string OUT
  SET @tm tr = 'EXEC master.. _addlogin '' + @name
  + '', NULL, @sid = ' + @SID_string + ', @encryptopt = '
  END
  IF (@xstatus &am  2048) = 2048
  -- login upgraded from 6.5
  SET @tm tr = @tm tr + ''skip_encryption_old''
  ELSE
  SET @tm tr = @tm tr + ''skip_encryption''
  PRINT @tm tr
  END
  END
  FETCH NEXT FROM login_curs INTO @SID_varbinary, @name, @xstatus, @bi wd
  END
  CLOSE login_curs
  DEALLOCATE login_curs
  RETURN 0
  GO
  ----- End Script -----
 
2、在创建  _help_revlogin 存储过程后,请从源服务器上的查询分析器中运行  _help_revlogin 过程。 _help_revlogin 存储过程可同时用于 SQL Server 7.0 和 SQL Server 2000。 _help_revlogin 存储过程的输出是登录脚本,该脚本可创建带有原始 SID 和密码的登录。保存输出,然后将其粘贴到目标 SQL Server 上的查询分析器中,并运行它。例如:EXEC master.. _help_revlogin

备注

 ull; 在目标 SQL Server 上运行输出脚本之前,请认真查看此脚本。如果必须将登录传输到与 SQL Server 源实例不在同一个域中的 SQL Server 实例,请编辑由  _help_revlogin 过程生成的脚本,并在  _grantlogin 语句中将域名替换为新的域名。由于在新域中被授予访问权的集成登录与原始域中的登录具有不同的 SID,因此数据库用户将从这些登录中孤立出去。要解决这些孤立用户,请查看以下项目符号项中引用的文章。如果在同一个域中的 SQL Server 实例之间传输集成登录,则会使用相同的 SID,而且用户不太可能被孤立。

 ull; 在移动登录之后,用户将不再具有访问已被同时移动的数据库的权限。此问题称为“孤立用户”。如果尝试将访问此数据库的权限授予该登录,则可能会失败,这表明该用户已存在:

Microsoft SQL-DMO (ODBC SQLState:42000) Error 15023:User or role '%s' already exists in the current database.

有关如何将登录映射到数据库用户以解决孤立的 SQL Server 登录和集成登录的说明,请查看相关文章:

(http://su ort.microsoft.com/kb/240872/) 如何解决在运行 SQL Server 的服务器之间移动数据库时的权限问题。

有关使用  _change_users_login 存储过程逐个解决孤立用户(仅能解决从标准 SQL 登录中孤立出去的用户)的说明,请查看相关文章:

(http://su ort.microsoft.com/kb/274188/) PRB:联机丛书中的“孤立用户疑难解答”主题不完整。

 ull; 如果传输登录和密码是向运行 SQL Server 的新服务器移动数据库的一部分,请查看相关文章,以了解对所涉及的工作流程和步骤的说明:

(http://su ort.microsoft.com/kb/314546/) 如何在运行 SQL Server 的计算机之间移动数据库。

 ull; 能够这样做的原因在于: _addlogin 系统存储过程中的 @encryptopt 参数允许通过使用加密密码来创建登录。有关此过程的更多信息,请参见 SQL Server 联机丛书中的&ldquo _addlogin (T-SQL)”主题。

 ull; 默认情况下,只有 sysadminfixed 服务器角色的成员可以从 sysxlogi  表中进行选择。除非 sysadmin 角色的成员授予了必要的权限,否则最终用户将无法创建或运行这些存储过程。

 ull; 此方法不会尝试传输特定登录的默认数据库信息,因为默认数据库并不始终存在于目标服务器中。要为某个登录定义默认数据库,您可以使用  _defaultdb 系统存储过程,方法是将登录名和默认数据库作为参数传递给该过程。有关使用此过程的更多信息,请参见 SQL Server 联机丛书中的&ldquo _defaultd rdquo;主题。

 ull; 在 SQL Server 实例之间传输登录的过程中,如果源服务器的排序顺序不区分大小写,而目标服务器的排序顺序区分大小写,则在将登录传输到目标服务器后,必须以大写形式输入密码中的所有字母字符。如果源服务器的排序顺序区分大小写,而目标服务器的排序顺序不区分大小写,则无法通过本文所述的步骤使用已传输的登录进行登录,除非原始密码不包括字母字符或原始密码中的所有字母字符都是大写字符。如果两个服务器都区分大小写或者都不区分大小写,则不会出现此问题。这是 SQL Server 处理密码的方式所带来的副作用。有关更多信息,请参见 SQL Server 7.0 联机丛书中的“Effect on Pa words of Changing Sort Order rdquo;(更改排序顺序对密码的影响)主题。

 ull; 在目标服务器上运行&ldquo _help_revlogi rdquo;脚本的输出时,如果该目标服务器已经定义了一个登录,且该登录名与脚本输出中的某个登录名相同,则在执行&ldquo _help_revlogi rdquo;脚本的输出时,可能会看到下面的错误:

Server:Msg 15025, Level 16, State 1, Procedure  _addlogin, Line 56

The login 'test1' already exists.

同样,如果此服务器上存在其他登录,且其 SID 值与您要尝试添加的登录的 SID 值相同,则会收到以下错误消息:

Server:Msg 15433, Level 16, State 1, Procedure  _addlogin, Line 93

Su lied parameter @sid is in use.

因此,您必须仔细复查这些命令的输出,检查 sysxlogi  表的内容,并相应地解决这些错误。

 ull; 特定登录的 SID 值用作在 SQL Server 中实现数据库级别访问的基础。因此,如果同一登录在该数据库级别(在该服务器上的两个不同数据库中)有两个不同的 SID 值,则此登录将仅能访问其 SID 与该登录的 syslogi  中的值相匹配的数据库。如果所讨论的两个数据库已从两个不同的服务器合并在一起,则可能出现这种情形。要解决此问题,必须使用  _dropuser 存储过程从具有不匹配 SID 的数据库中手动删除所讨论的登录,然后再使用  _adduser 存储过程添加它。

这篇文章中的信息适用于:

 ull; Microsoft SQL Server 7.0 标准版

 ull; Microsoft SQL Server 2000 Personal Edition Service Pack 3

 ull; Microsoft SQL Server 2000 标准版

 ull; Microsoft SQL Server 2000 Workgroup Edition

 ull; Microsoft SQL Server 2000 Developer Edition

 ull; Microsoft SQL Server 2000 Enterprise Edition

 ull; Microsoft SQL Server 2005 Standard Edition

 ull; Microsoft SQL 2005 Server Workgroup

 ull; Microsoft SQL Server 2005 Developer Edition

 ull; Microsoft SQL 2005 Server Enterprise

责任编辑:


相关文章
在SQL Server中需要避免的查询设计错误
在SQL Server下数据库链接的使用
 

最新文章

更多

· 巧用一条SQL 实现其它进...
· 解析:在SQL Server下数...
· 轻松掌握什么是层次型 基...
· 细化解析:SQL Server 2...
· 轻松掌握向外扩展数据库...
· 解析:正确的理解四类数...
· 处理SQL Server 2000的命...
· 轻松接触SQL Server 200...
· 细化解析:处理 SQL Ser...
· 教你轻松掌握怎样 创建新...

推荐文章

更多

· 巧用一条SQL 实现其它进...
· 解析:在SQL Server下数...
· 轻松掌握什么是层次型 基...
· 细化解析:SQL Server 2...
· 轻松掌握向外扩展数据库...
· 解析:正确的理解四类数...
· 处理SQL Server 2000的命...
· 轻松接触SQL Server 200...
· 细化解析:处理 SQL Ser...
· 教你轻松掌握怎样 创建新...

热点文章

更多