dbo是什麼

        dbo是具有在数据库中执行所有活动的暗示性权限的用户。将固定服务器角色   sysadmin   的任何成员都映射到每个数据库内称为dbo 的一个特殊用户上。另外,由固定服务器角色   sysadmin   的任何成员创建的任何对象都自动属于dbo.   
    
       例如,如果用户   Andrew   是固定服务器角色   sysadmin   的成员,并创建表   T1,则表   T1   属于dbo,并以dbo.T1   而不是   Andrew.T1   进行限定。相反,如果   Andrew   不是固定服务器角色   sysadmin   的成员,而只是固定数据库角色   db_owner   的成员,并创建表   T1,则   T1   属于   Andrew,并限定为   Andrew.T1。该表属于   Andrew,因为该成员没有将表限定为dbo.T1。  
   
       无法删除dbo用户,且此用户始终出现在每个数据库中。  
   
       只有由   sysadmin   固定服务器角色成员(或dbo用户)创建的对象才属于dbo。由任何其他也不是   syadmin   固定服务器角色成员的用户(包括   db_owner   固定数据库角色成员)创建的对象: 属于创建该对象的用户,而不是dbo,  用创建该对象的用户名限定.

      有一個数据库,SQL Server2005,給开发人员帐号为b2b,有创建表、视图、存储过程、函数和执行存储过程的权限,发现这个数据库下有些存储过程的架构为b2b,而不是dbo。创建对象的时候,如果默认架构不是dbo,如果不指定所有者名,则是用当前用户做为所有者.若要访问非默认架构中的对象,则必须至少指定一个由两部分构成的标识符 (schema_name.object_name)。引用架构范围内的对象的所有 DDL 和 DML 语句都必须符合此要求。如果对象的所有者不是dbo,那么在引用的时候就要显示指定表的所有者。所以如果不知道对象的所有者是谁,访问就很不方便。     我们可以修改它:

exec sp_changeobjectowner  'b2b.pro_process_po_track','dbo';

备注:

此存储过程只针对 Microsoft SQL Server 2000 中可用的对象进行。

此存储过程会删除对象中的所有现有权限,在运行 sp_changeobjectowner 之后,必须重新应用要保留的任何权限。

ALTER SCHEMA dbo TRANSFER b2b.pro_process_po_track;

备注:

ALTER SCHEMA 仅可用于在同一数据库中的架构之间移动对象。

目的架构下不能有同名的对象,否则会报错。

将对象移入新架构时,将删除与该对象关联的全部权限。如果已显式设置对象所有者,则该所有者保持不变。如果对象所有者设置为 SCHEMA OWNER,则该所有者将保持为 SCHEMA OWNER;但移动之后,SCHEMA OWNER 将解析为新架构的所有者。新所有者的 principal_id 将为 NULL。

 

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/10640532/viewspace-524663/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/10640532/viewspace-524663/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值