1. 首先在 SQL Server 服务器级别,建立登录账户(create login)数据库
create login system_dbowner with password='usercode1', default_database=订单数据库
登录账户名为:“system_dbowner”,登录密码:"usercode1”,默认链接到的数据库:“订单数据库”。服务器
默认链接到的数据库:“订单数据库”。 这时候,system_dbowner 账户就能够链接到 SQL Server 服务器上了。可是此时还不能 访问数据库中的对象(严格的说,此时system_dbowner 账户默认是 guest 数据库用户身份, 能够访问 guest 可以访问的数据库对象)。要使 system_dbowner 账户可以在 “订单数据库”中访问本身须要的对象, 须要在数据库 “订单数据库” 中创建一个“数据库用户”,赋予这个“数据库用户” 某些访问权限,而且把登录账户“system_dbowner” 和这个“数据库用户” 映射起来。 习惯上,“数据库用户” 的名字和 “登录账户”的名字相同,即:“system_dbowner”。 建立“数据库用户”和创建映射关系只须要一步便可完成。spa
2. 建立数据库用户(create user):code
create user system_dbowner for login system_dbowner with default_schema=dbo
并指定数据库用户“system_dbowner” 的默认 schema 是“订单数据库”。对象
这意味着 用户“system_dbowner” 在执行“select * from t”,实际上执行的是 “select * from 订单数据库.t”。blog
3. 经过加入数据库角色,赋予数据库用户“dba”权限:it
exec sp_addrolemember 'db_owner', 'system_dbowner'
此时,system_dbowner就能够全权管理数据库“订单数据库” 中的对象了。class
若是想让 SQL Server 登录账户“system_dbowner”访问多个数据库,好比 mydb2。 可让 sa 执行下面的语句:
--让 SQL Server 登录账户“dba”访问多个数据库登录
use mydb2 go create user system_dbowner for login system_dbowner with default_schema=dbo go exec sp_addrolemember 'db_owner', 'system_dbowner' go
此时,dba 就能够有两个数据库 mydb, mydb2 的管理权限了!date
4.受权
(1)授予大权限,除select等(system_daowner是角色)
grant all to system_dbowner;
(2)授予对整个数据库的查询、插入、删除、更新权限(此时不含有on关键字)
grant select,update,insert,delete to system_dbowner
(3)授予对数据库中的某些表格的查询、插入、删除、更新权限(此时含有on关键字)
grant select,update,insert,delete on 订单 to system_dbowner
(4)回收权限
revoke all to system_dbowner revoke select,update,insert,delete to system_dbowner
(5)删除角色
drop user system_dbowner
(6)删除登陆名
drop login system_dbowner