在SQL Server中看见很多表名都有前缀dbo,但是不写也可以。比如pubs的数据库中的表dbo.title


1. dbo是一个构架(schema),在sql2005中,表的调用格式如下:"数据库名.构架名.表名",同一个用户可以被授权访问多个构架,也可以被禁止访问某个或多个构架,这就是2005中提倡的"用户与构架分离"的概念. 在2005中,如果在创建表时没有指定构架(schema),那么系统默认该表的构架是dbo,所以会出现很多表名前自动加上dbo.字符样式. 
2.DBO是每个数据库的默认用户,具有所有者权限,即DbOwner 
 

dbo是默认用户也是架构,dbo作为架构是为了更好的与2000兼容,在2005前,没有架构的概念,只有用户的概念,那时候DBO是默认用户,大部分的数据库对象都是dbo的,到了2005,有了架构概念,但是为了向后兼容,保留了DBO,并且把DBO作为默认架构,在不指定架构的情况下,默认为dbo
在2000中DataBaseName.dbo.TableName解释为:数据库名.用户名.表名,
在2005中DataBaseName.dbo.TableName解释为:数据库名.架构名.表名,
这样2000中的代码移植到2005中就不会报错(dbo在2005中是默认的架构,创建表时,如不指定架构,则默认为属于dbo为个架构)。

如果要调用远程的数据库(如:数据名Skey,它是Sql2005),就要按照Skey.DataBaseName.dbo.TableName 

虽然 SQL Server 2000 包含 CREATE SCHEMA 语句,但实际上并不会像上面所定义的那样创建架构。在 SQL Server 2000 中,数据库用户和架构是隐式连接在一起的。每个数据库用户都是与该用户同名的架构的所有者。对象的所有者在功能上与包含它的架构所有者相同。因而,SQL Server 2000 中的完全限定名称的“架构”也是数据库中的用户。

在 SQL Server 2005 中,架构独立于创建它们的数据库用户而存在。可以在不更改架构名称的情况下转让架构的所有权。并且可以在架构中创建具有用户友好名称的对象,明确指示对象的功能。

SQL Server 2005 还引入了“默认架构”的概念,用于解析未使用其完全限定名称引用的对象的名称。在 SQL Server 2000 中,首先检查的是调用数据库用户所拥有的架构,然后是 DBO 拥有的架构。在 SQL Server 2005 中,每个用户都有一个默认架构,用于指定服务器在解析对象的名称时将要搜索的第一个架构。可以使用 CREATE USER 和 ALTER USER 的 DEFAULT_SCHEMA 选项设置和更改默认架构。如果未定义 DEFAULT_SCHEMA,则数据库用户将把 DBO 作为其默认架构。

sql server中的登录名,用户,架构,模式,角色,所有者,登录名,dbo之间的关系

登录名是登录数据库服务器时候用的

用户指的是某个具体的数据库中的用户。管理员可以设置登录名和具体的数据库中的用户的映射关系。

下面为了方面,用用户简称某个具体数据库中的用户。

在数据库中。例如在学生选课数据库中,可以有多个用户,每个用户可以有多个模式(在smss中叫做架构,模式的意义就是定义命名空间,防止出现命名冲突),每个模式可以有多张表。注意每个模式只能属于某一个用户。

 

所有者是一个数据库服务器的登录名,假设A登录数据库服务器,创建了一个数据库,这个数据库的所有者就是A。

 

dbo这是有两个意思,一个是用户dbo,相当linux中的root用户,拥有最高权限,用windows身份验证登录进去,映射到具体数据库中就是dbo用户;二是模式dbo,默认属于用户dbo,是用户dbo的一个默认命名空间。
 

 

Logo

开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!

更多推荐