关于修改数据库服务器登录名与数据库用户名之间的对应问题
来源:互联网 发布:矩阵特征向量的求法 编辑:程序博客网 时间:2024/05/17 07:37
问题:
我现在做一asp.net的网站,后台用的是SQL Server 2000数据库。在数据库服务器安全性目录下建有三个不同的登录名,在数据库中建有三个不同权限的,与三个登录名一一对应的同名用户。由于白天在单位做,晚上在家作,经常要在家和单位相互拷贝数据库,但不管我是用拷贝*.MDF和*.LDF的方法,还是用备份、还原数据库的方法都无法将数据库原封不动的复制,总是出现,三个数据库用户丢失对应的登录名,而数据库服务器安全性目录下的三个登录名却依然存在。
单位用windows 2000 professional系统,家里用的是Windowsxp Professianl系统
请问:1、如何完整复制数据库。
2、如果不能在两台机器之间完整复制数据库,如何为用户名添加或修改登录名
自己解决办法:
调用系统过程sp_change_users_login
尽管问题解决了,但我仍想知道为什么会出现“三个数据库用户丢失对应的登录名,而数据库服务器安全性目录下的三个登录名却依然存在”的问题,是SQL 2000的bug吗
sp_change_users_login
更改当前数据库中 SQL Server 用户与 Microsoft® SQL Server™ 登录之间的关系。
语法
sp_change_users_login [ @Action = ] 'action'
[ , [ @UserNamePattern = ] 'user' ]
[ , [ @login
Name = ] 'login' ]
参数
[ @Action = ] 'action'
描述此过程要执行的操作。action 的数据类型为 varchar(10),可以是下面的某个值。
user 必须是当前数据库中的有效用户,login 必须为 NULL、长度为零的字符串 ('') 或不指定。
Report 列出当前数据库中未链接到任何登录的用户及其对应的安全标识号 (SID)。user 和 login 必须为 NULL、长度为零的字符串 ('') 或不指定。
Update_One 将当前数据库中指定的 user 链接到 login。login 必须已经存在。必须指定 user 和 login。[@UserNamePattern =] 'user'
是当前数据库中的 SQL Server 用户的名称。user 的数据类型为 sysname,默认值为 NULL。sp_change_users_login 只能用于 SQL Server 登录和用户的安全帐户;而不能用于 Microsoft Windows NT® 用户。
[@LoginName =] 'login'
SQL Server 登录的名称。login 的数据类型为 sysname,默认值为 NULL。
返回代码值
0(成功)或 1(失败)
结果集
注释
使用此过程将当前数据库中用户的安全帐户链接到不同的登录。如果用户登录已更改,则使用 sp_change_users_login 将用户链接到新的登录,而不会丢失用户的权限。
login 不能为 sa,而 user 不能为 dbo、guest 或 INFORMATION_SCHEMA 用户。
不能在用户定义的事务中执行 sp_change_users_login。
权限
任何 public 角色的成员均可执行带有 Report 选项的 sp_change_users_login。只有 sysadmin 固定服务器角色的成员才能指定 Auto_Fix 选项。只有 sysadmin 或 db_owner 角色的成员才能指定 Update_One 选项。
示例
A. 显示登录映射的当前用户的报告
下面的示例生成当前数据库中的用户及其安全标识符的报告。
EXEC sp_change_users_login 'Report'
B. 更改用户的登录
下面的示例更改 pubs 数据库中的用户 Mary 与现有登录之间的链接,链接到新的登录 NewMary 上(使用 sp_addlogin 添加)。
--Add the new login.USE mastergoEXEC sp_addlogin 'NewMary'go--Change the user account to link with the 'NewMary' login.USE pubsgoEXEC sp_change_users_login 'Update_One', 'Mary', 'NewMary'
- 关于修改数据库服务器登录名与数据库用户名之间的对应问题
- sql server登录名与数据库用户名dbo的差别
- sql server登录名与数据库用户名dbo的差别
- mysql登录名与数据库的问题
- 修改数据库服务器名
- 关于数据库登陆名和数据库用户名的一点点心得
- SQL Server将数据库的用户名映射到登录名
- SQL Server将数据库的用户名映射到登录名
- SQL数据库中登录名和用户名的比喻关系
- SQL Server将数据库的用户名映射到登录名
- 数据库用户名映射为登录名
- Sql server 2008 登录名、数据库用户名、数据库角色成员,服务器角色
- SQL Server中的服务器登录名,服务器角色,数据库中的用户名,数据库中的角色,数据库中的架构的区别联系,关系
- sys使用用户名密码的方式本地登录数据库服务器
- SQL Server 登录名、服务器角色、用户名和数据库角色 --- 解释
- 关于用户名登录的问题
- sqlserver里服务器角色,服务器登录名,数据库用户,数据库角色,数据库架构的理解
- 服务器登录名、角色、数据库用户、角色、架构的关系
- 转载一篇有趣的文章 -- 追MM与设计模式
- DB2 SQL存储过程语法官方权威指南
- 源代码的安装与卸载
- Eclipse "Unable to install breakpoint due to missing line number attributes..."
- linux软件安装文件
- 关于修改数据库服务器登录名与数据库用户名之间的对应问题
- 生活中的病毒式营销
- JS错误定位方法
- 下一阶段实训安排
- 也谈GWT vs JSF
- oracle分页查询
- 程序员如何接私单做SOHO一族
- 2005年华为招聘--C语言笔试试题及参考答案
- Java模式之Factory 和 Bulider