角色
当几个用户需要在某个特定的数据库中执行类似的动作时(这里没有相应的Windows用户组),就可以向该数据库中添加一个角色(role)。指定了可以访问相同数据库对象的一组数据库用户。的成员可以分为如下几类:Windows用户组或用户账户 Server登录其他角色 Server的安全体系结构中包括了几个含有特定隐含的角色。除了数据库拥有者创建的角色之外,还有两类预定义的角色。这些可以创建的角色可以分为如下几类:固定服务器固定数据库用户自定义固定服务器
由于固定服务器是在服务器层次上定义的,因此它们位于从属于数据库服务器的数据库外面。下表列出了所有现有的固定。 固定 | 说 明 |
sysadmin | 执行 Server中的任何动作 |
serveradmin | 配置服务器设置 |
setupadmin | 安装复制和管理扩展过程 |
securityadmin | 管理登录和CREATE DATABASE的以及阅读审计 |
processadmin | 管理 Server进程 |
dbcreator | 创建和修改数据库 |
diskadmin | 管理磁盘文件 |
sa登录
sa登录是系统管理员的登录。在以前的 Server版本中不存在角色,sa登录具有所有可能的关于系统管理工作的。在 Server 2005中,sa登录保持了向后兼容性。sa登录永远是固定syadmin中的成员,并且不能从该角色中删除。注意:只有当没有其他方法登录到 Server系统中时,再使用sa登录。固定及其
在某个 Server系统中,每个固定都有其隐含的。使用系统过程sp_srvrolepermission可以浏览每个固定的。该系统过程的语法形式为:sp_srvrolepermission[[@srvrolename =] 'role']如果没有指定role的值,那么所有的固定的都将显示出来。下面的部分将讨论每个固定的。1. sysadmin
固定sysadmin的成员被赋予了 Server系统中所有可能的。例如,只有这个角色中的成员(或一个被这个角色中的成员赋予了CREATE DATABASE的用户)才能够创建数据库。固定和sa登录之间有着特殊的关系。sa登录一直都是固定中的成员,并且不能从该角色中删除。2. serveradmin
固定serveradmin的成员可以执行如下的动作:向该中添加其他登录运行dbcc pin命令(从而使表常驻于主中)运行系统过程sp_configure(以显示或更改系统选项)运行reconfigure选项(以更新系统过程sp_configure所做的所有改动)使用shutdown命令关掉数据库服务器运行系统过程sp_option为用户自定义表设置选项的值3. setupadmin
固定setupadmin中的成员可以执行如下的动作:向该中添加其他登录添加、删除或配置链接的服务器执行一些系统过程,如sp_serveroption4. securityadmin
固定securitypadmin中的成员可以执行关于服务器访问和安全的所有动作。这些成员可以进行如下的系统动作:向该中添加其他登录读取 Server的错误日志运行如下的系统过程:如sp_addlinkedsrvlogin、sp_addlogin、sp_defaultdb、sp_defaultlanguage、sp_denylogin、sp_droplinkedsrvlogin、sp_droplogin、sp_grantlogin、sp_helplogins、sp_remoteoption和sp_revokelogin(所有这些系统过程都与系统安全相关。)5. processadmin
固定processadmin中的成员用来管理 Server进程,如中止用户正在运行的查询。这些成员可以进行如下的动作:向该中添加其他登录执行KILL命令(以取消用户进程)6. dbcreator
固定dbcreator中的成员用来管理与数据库创建和修改有关的所有动作。这些成员可以进行如下的动作:向该中添加其他登录运行CREATE DATABASE和ALTER DATABASE使用系统过程sp_renamedb来修改数据库的名称7. diskadmin
固定diskadmin的成员可以进行如下与用来存储数据库对象的文件和文件组有关的动作:向该中添加其他登录运行如下系统过程:sp_ddumpdevice和sp_dropdevice。运行DISK INIT固定
固定在数据库层上进行定义,因此它们存在于属于数据库服务器的每个数据库中。下表列出了所有的固定。 固定 | 说 明 |
db_owner | 可以执行数据库中技术所有动作的用户 |
db_accessadmin | 可以添加、删除用户的用户 |
db_datareader | 可以查看所有数据库中用户表内数据的用户 |
db_datawriter | 可以添加、修改或删除所有数据库中用户表内数据的用户 |
db_ddladmin | 可以在数据库中执行所有DDL操作的用户 |
db_securityadmin | 可以管理数据库中与安全有关所有动作的用户 |
db_backoperator | 可以备份数据库的用户(并可以发布DBCC和CHECKPOINT,这两个一般在备份前都会被执行) |
db_denydatareader | 不能看到数据库中任何数据的用户 |
db_denydatawriter | 不能改变数据库中任何数据的用户 |