创建角色,用户,权限
/*--示例说明
示例在数据库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