집 >데이터 베이스 >MySQL 튜토리얼 >更改SQL Server更改当前数据库的所有者:sp_changedbowner
更改SQL Server更改当前数据库的所有者:sp_changedbowner
更改当前数据库中 SQL Server 用户与 Microsoft® SQL Server™ 登录之间的关系。
<b>sp_change_users_login</b> [ <b>@Action</b> <b>= </b>] <b>'</b><i>action</i><b>'</b>
[ <b>, </b>[ <b>@UserNamePattern</b> <b>= </b>] <b>'</b><i>user</i><b>' </b>]
[ <b>, </b>[ <b>@login</b>
Name <b>= </b>] <b>'</b><i>login</i><b>' </b>]
[ @Action = ] 'action'
描述此过程要执行的操作。action 的数据类型为 varchar(10),可以是下面的某个值。
[@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 选项。
下面的示例生成当前数据库中的用户及其安全标识符的报告。
<code>EXEC sp_change_users_login 'Report' </code>
下面的示例更改 pubs 数据库中的用户 Mary 与现有登录之间的链接,链接到新的登录 NewMary 上(使用 sp_addlogin 添加)。
<code>--Add the new login. USE master go EXEC sp_addlogin 'NewMary' go --Change the user account to link with the 'NewMary' login. USE pubs go EXEC sp_change_users_login 'Update_One', 'Mary', 'NewMary' </code>