SQL Server2005中登录名、用户名、角色和架构之间的关系

SQL20052000进行了很大的改进,而用户关系这部分也变得相当复杂了,很多朋友都对此一知半解!下面,我将把我应用中总结的和大家分享下,先从概念入手,希望对不理解的朋友有点提示。

今天我们要说的包括服务器登录名Server Login,服务器角色Server Role,数据库用户DB User,数据库架构DB Schema,数据库角色DB Role 。以上几个名词应该从服务器与数据库来区分,服务器包含一到多个数据库,其中:

服务器登录名:指有权限登录到某服务器的用户;

服务器角色:指一组固定的服务器用户,默认有9组;

·                     登录名一定属于某些角色,默认为public

·                     服务器角色不容许更改

·                     登录后也不一定有权限操作数据库

数据库用户:指有权限能操作数据库的用户;

数据库角色:指一组固定的有某些权限的数据库角色;

数据库架构:指数据库对象的容器;

·                     数据库用户对应于服务器登录名以便登录者可以操作数据库

·                     数据库角色可以添加,可以定制不同权限  

·                     数据库架构,类似于数据库对象的命名空间,用户通过架构访问数据库对象

而通过下图可以让这些概念清晰一些:

即:

1.           服务器登录名属于某组服务器角色;

2.           服务器登录名需要于数据库的用户映射后才拥有操作数据库的权限

3.           数据库用户属于某组数据库角色以获取操作数据库的权限

4.           数据库角色拥有对应的数据库架构,数据库用户可以通过角色直接拥有架构

5.           数据库用户有默认架构,写SQL语句可以直接以对象名访问

6.           非默认架构则要以架构名.对象名访问

因此,新建一个非SA账户并建立数据库的过程可以如下:

1、新建登录名Login1


2、新建数据库DB1

 

3、新建DB1的架构Schema1


 

4、新建BD1的用户User1,登录名对应Login1,默认架构选择Schema1,角色选择db_owner

 


 

5、在登录名Login1的属性窗口里选择用户映射,勾选DB1,在用户里填写User1,默认架构选择"Schema1"

你可能感兴趣的:(SQL Server)