创建角色,用户,权限

/*--示例说明
        示例在数据库pubs中创建一个拥有表jobs的所有权限、拥有表titles的SELECT权限的角色r_test
    随后创建了一个登录l_test,然后在数据库pubs中为登录l_test创建了用户账户u_test
    同时将用户账户u_test添加到角色r_test中,使其通过权限继承获取了与角色r_test一样的权限
    最后使用DENY语句拒绝了用户账户u_test对表titles的SELECT权限。
    经过这样的处理,使用l_test登录SQL Server实例后,它只具有表jobs的所有权限。
--*/

USE pubs

--创建角色 r_test
EXEC sp_addrole 'r_test'

--授予 r_test 对 jobs 表的所有权限
GRANT ALL ON jobs TO r_test

--授予角色 r_test 对 titles 表的 SELECT 权限
GRANT SELECT ON titles TO r_test

--添加登录 l_test,设置密码为pwd,默认数据库为pubs
EXEC sp_addlogin 'l_test','pwd','pubs'

--为登录 l_test 在数据库 pubs 中添加安全账户 u_test
EXEC sp_grantdbaccess 'l_test','u_test'

--添加 u_test 为角色 r_test 的成员
EXEC sp_addrolemember 'r_test','u_test'

--拒绝安全账户 u_test 对 titles 表的 SELECT 权限
DENY SELECT ON titles TO u_test

/*--完成上述步骤后,用 l_test 登录,可以对jobs表进行所有操作,但无法对titles表查询,虽然角色 r_test 有titles表的select权限,但已经在安全账户中明确拒绝了对titles的select权限,所以l_test无titles表的select权限--*/

--从数据库 pubs 中删除安全账户
EXEC sp_revokedbaccess 'u_test'

--删除登录 l_test
EXEC sp_droplogin 'l_test'

--删除角色 r_test
EXEC sp_droprole 'r_test'

 

/*创建登陆帐号:
   ⑴.添加windows登陆帐号
   语法:exec sp_grantlogin  '计算机名\用户名'
    ⑵.添加SQL登陆帐号
   语法:exec sp_addlogin  '用户名','密码'
 */

 /*创建数据库用户
  语法:exec sp_grantdbaccess  '登陆帐号','数据库用户'
 */

 /*想数据库授权
  语法:grant 权限 on 表名  to 数据库用户
  //注意:其中的权限包含有:insert 、delete 、update 、select 、create table等
 */
 
 /*
 撤消权限
  语法:revoke 权限 on 表名  from  '用户'
 */

 /*
 删除数据库用户
  语法:exec sp_dropuser '用户名'
 */

 /*
 删除登陆帐号
  语法:exec sp_droplogin '登陆名'
 */

--****************
/*三级权限设置*/
--****************
/**第一级**登录SQL SERVER的权限*/

--创建SQL Server 用户 ,'SQL'用户名,'abc' 密码
exec sp_addlogin 'SQL','abc','pubs'   --pubs默认数据库名

-- 授权windows用户 '计算机名\用户名'
exec sp_grantlogin 'jbst124\Win'
--修改默认数据库
exec sp_defaultdb 'jbst124\Win','pubs'

--删除登录
exec sp_droplogin 'SQL'
--取消授权
exec sp_revokelogin 'jbst124\Win'
/*--拒绝授权用户,不允许该用户访问,
--比如默认的系统管理员可以登录sql server 可以让其中一个不能访问
exec sp_denyLogin 'jbst124\ch'*/

/**第二级**对某个数据库进行操作的权限*/

--添加数据库用户,该用户可以对数据库进行操作
use MyDataBase
exec sp_grantdbAccess 'SQL','SQLdbo' --登录名和数据库用户名
--取消数据库用户授权
exec sp_revokedbaccess 'SQLdbo'

--授予权限
--创建数据库的权限,只能在maste数据库下才行
grant create database to SQLdbo
--创建新表
grant create table to SQLdbo

/**第三级**对数据库中表的操作的权限*/

--删除表
grant delete on abc to SQLdbo
--修改表
grant update on tablename to SQLdbo
--查询某个表的权限
grant select on tablename to SQLdbo

--拒绝权限
deny create table to SQLdbo
--取消权限
revoke create table to SQLdbo