首页 > 数据库技术 > 详细

SQL SERVER中[dbo]的解释

时间:2019-06-24 16:55:47      阅读:119      评论:0      收藏:0      [点我收藏+]

 

1.作用:
(1)DBO是每个数据库的默认用户,具有所有者权限,即DbOwner;
通过用DBO作为所有者来定义对象,能够使数据库中的任何用户引用而不必提供所有者名称。
(2)至于为什么要使用所有者进行限定,是因为不同的用户可能创建同名的对象,例如登录名me和登录名you在pubs数据库中分别创建了用户名me,和 you,这二个用户都创建了
testtable这个同名表,而这二个表虽然同名但结构或数据可能完全不同,为了避免调用错误,必须使用所有者名称进行限定. 
2.举例:
比如:你以User1登录进去并建表Table,而未指定DBO,当用户User2登进去想访问Table时就得知道这个Table是你User1建立的,要写上User1.Table,如果他不知道是你建的,则访问会有问题。
如果你建表时把所有者指给了Dbo,则别的用户进来时写上Dbo.Table就行了,不必知道User1。
3.扩展:
怎样来调用别的用户创建的对象呢?例如me用户访问you用户创建的表或访问dbo创建的表.此种情况,必须同时满足二个条件: 
(1)将me用户的数据库角色设置为db_owner,否则无法访问其他用户(包括dbo用户)创建的对象.(企业管理器-> 用户,右键菜单 <属性> 中设置) 
(2)使用所有者进行限定. 
例如me访问you创建的testtable: 
select   *   from   you.testtable 
不光表是如此,视图等等数据库对象建立时也要如此才算是好。

SQL SERVER中[dbo]的解释

原文:https://www.cnblogs.com/guorongtao/p/11077735.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!