SQL SERVER中[dbo]的解释
1.作用:
(1)DBO是每个数据库的默认用户,具有所有者权限,即DbOwner;
通过用DBO作为所有者来定义对象,能够使数据库中的任何用户引用而不必提供所有者名称。
(2)至于为什么要使用所有者进行限定,是因为不同的用户可能创建同名的对象,例如登录名me和登录名you在pubs数据库中分别创建了用户名me,和 you,这二个用户都创建了
testtable这个同名表,而这二个表虽然同名但结构或数据可能完全不同,为了避免调用错误,必须使用所有者名称进行限定.
如果你建表时把所有者指给了Dbo,则别的用户进来时写上Dbo.Table就行了,不必知道User1。
(1)将me用户的数据库角色设置为db_owner,否则无法访问其他用户(包括dbo用户)创建的对象.(企业管理器-> 用户,右键菜单 <属性> 中设置)
(2)使用所有者进行限定.
例如me访问you创建的testtable:
select * from you.testtable
不光表是如此,视图等等数据库对象建立时也要如此才算是好。
通过用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
不光表是如此,视图等等数据库对象建立时也要如此才算是好。
博客园 滔Roy https://www.cnblogs.com/guorongtao 希望内容对你有所帮助,谢谢!