日期:2014-05-18  浏览次数:20621 次

求救:如何删除和建立Sql Server2K的连接用户名?
因原电脑的操作系统有问题,所以新换了块硬盘,并装上   windows   2K   server和Sql   Server   2K,把原有的数据库文件(*.MDF和*.LDF)直接复制新硬盘的相同目录上,并用附加数据库方式,附加到Sql   Server企业管理器里。

因原系统上我设置了多个连接用户名及密码,并各自拥有不同的数据库权限。
又因为Sql   Server是新安装,所以“安全性/登录”不存在这些用户名,现在我想重新再设置这些用户名和密码和原来的一样,企业管理器却无法创建同样的用户,因为在相应的数据库上已存在以前设置的用户,想删也删不掉,删除时提示“因为选定的用户拥有对象,所以无法除去该用户”。

在“安全性/登录”创建用户时又提示:“错误21002:[SQL-DMO]用户XX已存在”。

好郁闷啊!!

我该怎样才能删除原来旧的连接用户,再新建同样的用户名和密码?

高手们快救救我啊!!!!


------解决方案--------------------
将数据库-> 用户中将用户删掉
------解决方案--------------------
--切换到你新增的用户要控制的数据库
use 你的库名
go

--新增用户
exec sp_addlogin 'test ' --添加登录
exec sp_grantdbaccess N 'test ' --使其成为当前数据库的合法用户
exec sp_addrolemember N 'db_owner ', N 'test ' --授予对自己数据库的所有权限
go

--这样创建的用户就只能访问自己的数据库,及数据库中包含了guest用户的公共表

--删除测试用户
exec sp_revokedbaccess N 'test ' --移除对数据库的访问权限
exec sp_droplogin N 'test ' --删除登录
------解决方案--------------------
使用 sp_change_users_login 将当前数据库中的数据库用户链接到 SQL Server 登录名。如果用户登录名已更改,则使用 sp_change_users_login 将用户链接到新的登录,而不会丢失用户的权限。新的 login 不能为 sa,而 user 不能为 dbo、guest 或 INFORMATION_SCHEMA 用户。

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

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

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

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

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

Update_One
将当前数据库中的指定 user 链接到现有 SQL Server login。必须指定 user 和 login。password 必须为 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。

------解决方案--------------------
关注