`
linqincai
  • 浏览: 24544 次
  • 性别: Icon_minigender_1
  • 来自: 温州
社区版块
存档分类
最新评论

使用SQL语句赋予SQL Server数据库登录用户权限

阅读更多

本文转载自:

 

GRANT

在安全系统中创建项目,使当前数据库中的用户得以处理当前数据库中的数据或执行特定的 Transact-SQL 语句。

语法

语句权限:

GRANT { ALL | statement [ ,...n ] }
TO security_account [ ,...n ]

对象权限:

GRANT
    { ALL [ PRIVILEGES ] | permission [ ,...n ] }
    {
        [ ( column [ ,...n ] ) ] ON { table | view
}
        | ON { table | view } [ ( column [ ,...n ] ) ]
        | ON { stored_procedure | extended_procedure
}
        | ON { user_defined_function }
    }
TO security_account [ ,...n ]
[ WITH GRANT OPTION ]
[ AS { group | role
} ]

参数

ALL

表示授予所有可用的权限。对于语句权限,只有 sysadmin 角色成员可以使用 ALL。对于对象权限,sysadmin db_owner 角色成员和数据库对象所有者都可以使用 ALL。

statement

是被授予权限的语句。语句列表可以包括:

  • CREATE DATABASE

  • CREATE DEFAULT

  • CREATE FUNCTION

  • CREATE PROCEDURE

  • CREATE RULE

  • CREATE TABLE

  • CREATE VIEW

  • BACKUP DATABASE

  • BACKUP LOG

n

一个占位符,表示此项可在逗号分隔的列表中重复。

TO

指定安全帐户列表。

security_account

是权限将应用的安全帐户。安全帐户可以是:

  • Microsoft® SQL Server™ 用户。

  • SQL Server 角色。

  • Microsoft Windows NT® 用户。

  • Windows NT 组。

当权限被授予一个 SQL Server 用户或 Windows NT 用户帐户,指定的 security_account 是权限能影响到的唯一帐户。若权限被授予 SQL Server 角色或 Windows NT 组,权限可影响到当前数据库中该组或该角色成员的所有用户。若组或角色和它们的成员之间存在权限冲突,最严格的权限 (DENY) 优先起作用。security_account 必须在当前数据库中存在;不可将权限授予其它数据库中的用户、角色或组,除非已为该用户在当前数据库中创建或给予了访问权限。

两个特殊的安全帐户可用于 GRANT 语句。授予 public 角色的权限可应用于数据库中的所有用户。授予 guest 用户的权限可为所有在数据库中没有用户帐户的用户使用。

当授予某个 Windows NT 本地组或全局组权限时,请指定在其上定义该组的域名或计算机名,然后依次输入反斜线和组名。但是,若要授予访问 Windows NT 内置本地组的权限,请指定 BUILTIN 而不是域名或计算机名。

PRIVILEGES

是可以包含在符合 SQL-92 标准的语句中的可选关键字。

permission

是当前授予的对象权限。当在表、表值函数或视图上授予对象权限时,权限列表可以包括这些权限中的一个或多个:SELECT、INSERT、DELETE、REFENENCES 或 UPDATE。列列表可以与 SELECT 和 UPDATE 权限一起提供。如果列列表未与 SELECT 和 UPDATE 权限一起提供,那么该权限应用于表、视图或表值函数中的所有列。

在存储过程上授予的对象权限只可以包括 EXECUTE。在标量值函数上授予的对象权限可以包括 EXECUTE 和 REFERENCES。

为在 SELECT 语句中访问某个列,该列上需要有 SELECT 权限。为使用 UPDATE 语句更新某个列,该列上需要有 UPDATE 权限。

为创建引用某个表的 FOREIGN KEY 约束,该表上需要有 REFERENCES 权限。

为使用引用某个对象的 WITH SCHEMABINDING 子句创建 FUNCTION 或 VIEW,该对象上需要有 REFERENCES 权限。

column

是当前数据库中授予权限的列名。

table

是当前数据库中授予权限的表名。

view

是当前数据库中被授予权限的视图名。

stored_procedure

是当前数据库中授予权限的存储过程名。

extended_procedure

是当前数据库中授予权限的扩展存储过程名。

user_defined_function

是当前数据库中授予权限的用户定义函数名。

WITH GRANT OPTION

表示给予了 security_account 将指定的对象权限授予其它安全帐户的能力。WITH GRANT OPTION 子句仅对对象权限有效。

AS {group | role}

指当前数据库中有执行 GRANT 语句权力的安全帐户的可选名。当对象上的权限被授予一个组或角色时使用 AS,对象权限需要进一步授予不是组或角色的成员的用户。因为只有用户(而不是组或角色)可执行 GRANT 语句,组或角色的特定成员授予组或角色权力之下的对象的权限。

注释

不允许有跨数据库权限;只能将当前数据库中的对象和语句的权限授予当前数据库中的用户。如果用户需要另一个数据库中的对象的权限,请在该数据库中创建用户帐户,或者授权用户帐户访问该数据库以及当前数据库。

<!--NOTE-->

说明  系统存储过程是例外,因为 EXECUTE 权限已经授予 public 角色,允许任何人去执行。但是在执行系统存储过程后,将检查用户的角色成员资格。如果此用户不是运行此存储过程所需要的适当的固定服务器或数据库角色的成员,则此存储过程不会继续执行。

<!--/NOTE-->

 

REVOKE 语句可用于删除已授予的权限,DENY 语句可用于防止用户通过 GRANT 语句获得权限给他们的用户帐户。

授予权限删除所授予级别(用户、组或角色)上的已拒绝权限或已废除权限。在另一级别(诸如包含此用户的组或角色)上被拒绝的同一权限优先起作用。但是,虽然在另一级别上所废除的同一权限仍然适用,但它并不阻止用户访问该对象。

如果用户激活应用程序角色,对此用户通过该应用程序角色访问的任何对象,GRANT 的作用为空。因此,尽管一个用户可能被授予了对当前数据库中的指定对象的访问权限,但是如果此用户使用对此对象无访问权限的应用程序角色,则在应用程序角色激活期间,此用户也没有此对象的访问权限。

sp_helprotect 系统存储过程报告在数据库对象或用户上的权限。

权限

GRANT 权限依赖于所授予的语句权限和权限中涉及的对象。sysadmin 角色中的成员可在任何数据库中授予任何权限。对象所有者可为他们所拥有的对象授予权限。db_ownerdb_securityadmin 角色的成员可授予其数据库中任何语句或对象上的任何权限。

需要权限的语句是那些在数据库中增加对象,或对数据库执行管理活动的语句。每条需要权限的语句都有一个特定的角色集,自动有权限执行此语句。例如,sysadmindb_ownerdb_ddladmin 角色的成员默认有CREATE TABLE 权限。sysadmin db_owner 角色以及表的所有者默认有对表执行 SELECT 语句的权限。

有一些 Transact-SQL 语句不能被授予权限;执行这些语句要求有固定角色中的成员资格,此角色有默示执行特殊语句的权限。例如,若要执行 SHUTDOWN 语句,用户必须添加为 serveradmin 角色中的成员。

dbcreator、processadminsecurityadminserveradmin 固定服务器角色的成员仅有权执行以下 Transact-SQL 语句。

 

语句 dbcreator processadmin securityadmin serveradmin bulkadmin
ALTER DATABASE X        
CREATE DATABASE X        
BULK INSERT         X
DBCC       X (1)  
DENY     X (2)    
GRANT     X (2)    
KILL   X      
RECONFIGURE       X  
RESTORE X        
REVOKE     X (2)    
SHUTDOWN       X  

(1) 有关更多信息,请参见 DBCC 语句。
(2) 仅适用于 CREATE DATABASE 语句。

<!--NOTE-->

说明  diskadminsetupadmin 固定服务器角色的成员没有权限执行任何 Transact-SQL 语句,他们只能执行特定的系统存储过程。但是,sysadmin 固定服务器角色的成员有权限执行所有的 Transact-SQL 语句。

<!--/NOTE-->

 

下面的固定数据库角色的成员有权限执行指定的 Transact-SQL 语句。

 


语句
db_owner
db_datareader
db_datawriter
db_ddladmin db_backupoperator db_securityadmin
ALTER DATABASE X     X    
ALTER FUNCTION X     X    
ALTER PROCEDURE X     X    
ALTER TABLE X (1)     X    
ALTER TRIGGER X     X    
ALTER VIEW X (1)     X    
BACKUP X       X  
CHECKPOINT X       X  
CREATE DEFAULT X     X    
CREATE FUNCTION X     X    
CREATE INDEX X (1)     X    
CREATE PROCEDURE X     X    
CREATE RULE X     X    
CREATE TABLE X     X    
CREATE TRIGGER X (1)     X    
CREATE VIEW X      X    
DBCC X       X (2)  
DELETE X (1)   X      
DENY X         X
DENY on object X          
DROP X (1)     X    
EXECUTE X (1)          
GRANT X         X
GRANT on object X (1)          
INSERT X (1)   X      
READTEXT X (1) X        
REFERENCES X (1)     X    
RESTORE X          
REVOKE X         X
REVOKE on object X (1)          
SELECT X (1) X        
SETUSER X          
TRUNCATE TABLE X (1)     X    
UPDATE X (1)   X      
UPDATE STATISTICS X (1)          
UPDATETEXT X (1)   X      
WRITETEXT X (1)   X      

(1) 权限也适用于对象所有者。
(2) 有关更多信息,请参见 DBCC 语句。

<!--NOTE-->

说明  db_accessadmin 固定数据库角色的成员没有执行任何 Transact-SQL 语句的权限,只可执行特定的系统存储过程。

<!--/NOTE-->

 

不需要权限即可执行的 Transact-SQL 语句有(已自动授予 public):

 

BEGIN TRANSACTION COMMIT TRANSACTION
PRINT RAISERROR
ROLLBACK TRANSACTION SAVE TRANSACTION
SET  

有关执行系统存储过程所需权限的更多信息,请参见相应的系统存储过程。

示例
A. 授予语句权限

下面的示例给用户 MaryJohn 以及 Windows NT 组 Corporate\BobJ 授予多个语句权限。

GRANT CREATE DATABASE, CREATE TABLE
TO Mary, John, [Corporate\BobJ]
B. 在权限层次中授予对象权限

下例显示权限的优先顺序。首先,给 public 角色授予 SELECT 权限。然后,将特定的权限授予用户 Mary、John Tom。于是这些用户就有了对 authors 表的所有权限。

USE pubs
GO

GRANT SELECT
ON authors
TO public
GO 

GRANT INSERT, UPDATE, DELETE
ON authors
TO Mary, John, Tom
GO
C. 给 SQL Server 角色授予权限

下面的示例将 CREATE TABLE 权限授予 Accounting 角色的所有成员。

GRANT CREATE TABLE TO Accounting
D. 用 AS 选项授予权限

用户 Jean 拥有表 Plan_DataJean 将表 Plan_Data 的 SELECT 权限授予 Accounting 角色(指定 WITH GRANT OPTION 子句)。用户 JillAccounting 的成员,他要将表 Plan_Data 上的 SELECT 权限授予用户 JackJack 不是 Accounting 的成员。

因为对表 Plan_Data 用 GRANT 语句授予其他用户 SELECT 权限的权限是授予 Accounting 角色而不是显式地授予 Jill,不能因为已授予 Accounting 角色中成员该权限,而使 Jill 能够授予表的权限。Jill 必须用 AS 子句来获得 Accounting 角色的授予权限。

/* User Jean */
GRANT SELECT ON Plan_Data TO Accounting WITH GRANT OPTION

/* User Jill */
GRANT SELECT ON Plan_Data TO Jack AS Accounting

<!--RELATEDTOPICSLIST-->

分享到:
评论

相关推荐

    SQL语句进行数据库权限设置

    本主题将深入探讨如何使用SQL语句进行数据库权限设置,以及SQL Server中的权限层次结构。 首先,我们需要理解SQL Server中的权限体系。权限分为两大类:对象权限和服务器权限。对象权限针对数据库内的具体对象,如...

    SQL Server数据库建用户授权

    SQL Server 数据库用户授权是指在 SQL Server 数据库中创建用户账户并赋予相应的权限,以便用户可以访问和管理数据库中的对象。本文将详细介绍如何使用 SQL 语句创建数据库用户,赋予用户权限,并对用户账户进行管理...

    在SQL Server中创建用户角色及授权(使用SQL语句) .pdf

    这篇文档主要讲述了如何使用SQL语句在SQL Server中创建用户角色并进行授权。首先,我们从创建登录账户开始,然后创建数据库用户,接着将登录账户与数据库用户关联,并通过加入数据库角色来赋予用户特定的权限。 1. ...

    SQL Server 数据库用户管理

    创建数据库用户有两种主要方法:使用SQL Server Management Studio (SSMS) 和T-SQL语句。 1. **使用SSMS创建数据库用户**: - 打开SSMS,连接到服务器,展开数据库,找到目标数据库,接着展开“安全性”节点,右键...

    浅谈SQL Server数据库应用程序中数据库的安全性.pdf

    在使用过程中,用户通过执行Transact-SQL语句激活应用程序角色,获取管理应用程序的权限,避免数据损坏造成损失。 4.网络连接策略 网络连接策略主要关注于如何在信息共享的过程中,保障SQL Server数据库的安全性。...

    SQLSERVER基本语句整合

    最后,数据控制涉及到权限和访问控制,"GRANT"语句用于赋予用户或角色特定的数据库操作权限,如`GRANT SELECT ON Customers TO UserA`允许UserA查询Customers表。"REVOKE"语句则用于撤销权限,"DENY"阻止权限。 在...

    SDE For SqlServer 2008 中使用独立用户和数据库.docx

    以下将详细介绍如何在SDE for SQL Server 2008中创建数据库、用户,并进行相应的权限设置。 1. 创建数据库: 在SQL Server Management Studio (SSMS) 中,首先你需要连接到SQL Server实例。然后,右键点击“数据库...

    SQLSERVER数据库异地备份[归类].pdf

    2. **命令行备份**:可以使用T-SQL语句结合`xp_cmdshell`来执行备份和文件操作。例如,以下脚本会删除7天前的旧备份,然后创建新的备份并将其复制到远程共享目录: - 使用`DECLARE @sql VARCHAR(500)`声明变量存储...

    数据库初级课件-sql语句初级学习

    "数据库初级课件-SQL语句初级学习"的主题涵盖了基础的SQL语法和在SQL Server中设置用户访问权限的实践。在这个教程中,我们将深入探讨SQL的基本概念以及如何在SQL Server环境下为用户提供安全、有效的访问控制。 ...

    浅谈SQL-Server数据库应用程序中数据库的安全性.doc

    创建应用程序角色后,用户需要通过执行特定的Transact-SQL语句并提供验证密码来激活角色,从而确保只有授权的用户才能行使相应权限。 网络连接策略在现代企业的数据管理中同样重要。为了保护SQL Server数据库免受...

    SqlServer教程:经典SQL语句集锦

    在SQL Server中,掌握基本的SQL语句是至关重要的,无论是初学者还是经验丰富的开发者,这些语句都是日常数据库管理的基础。以下是对标题和描述中提及的一些经典SQL语句的详细解释: 1. **DDL(数据定义语言)**:...

    sqlServer 2000数据库原理及应用书中的数据库

    1. SQL语言:SQL Server 2000支持标准SQL语句,如SELECT用于查询数据,INSERT用于插入数据,UPDATE用于更新数据,DELETE用于删除数据,以及CREATE/DROP/ALTER用于创建、删除和修改数据库对象。 2. 触发器:可以定义...

    用VB更改航管系统SQL_SERVER数据库的结构.pdf

    在探讨如何使用Visual Basic (VB)更改航管系统的SQL_SERVER数据库结构之前,首先需要了解几个关键知识点。这些知识点包括数据库的基本操作、SQL_SERVER的特点以及如何通过VB进行数据库编程。 ### 数据库基础知识 ...

    SQL Server数据库信息安全实施策略.pdf

    - 权限管理:是指对数据库用户和角色赋予或撤销特定权限的过程,可以细分为对象权限和语句权限,如SELECT、INSERT、UPDATE、DELETE等。 3. 安全策略的具体实现: - 使用SQL Server Management Studio(SSMS)进行...

    sqlserver数据库对接.docx

    总结来说,SQLServer数据库对接涉及用户创建、角色分配、权限设置和数据库链接的建立。这些步骤确保了安全且有效地访问和操作远程数据库资源。在实际应用中,还需要考虑性能优化、安全性策略以及错误处理等方面,以...

    图书管理系统 C# SQL SERVER.zip

    开发者使用SQL语句进行数据的增删改查,例如,创建图书表、用户表,执行借阅、归还等操作的事务处理。 三、系统架构 该图书管理系统采用典型的三层架构设计,包括表示层(UI)、业务逻辑层(BLL)和数据访问层(DAL...

    sql server 2008 数据库管理系统使用SQL语句创建登录用户步骤详解

    以下是一个详细的步骤指南,包括如何使用SQL语句创建登录用户,以及如何分配不同的服务器角色和数据库角色。 首先,创建一个新的登录用户,可以使用`CREATE LOGIN`语句。下面是一个示例: ```sql CREATE LOGIN ...

    NIIT博睿软件工程师第一学期使用 SQL Server 2005查询和管理数据库

    3. 数据控制语言(DCL):主要用于权限管理,如`GRANT`和`REVOKE`命令用于赋予或撤销用户对数据库对象的操作权限。 4. T-SQL(Transact-SQL):是SQL Server特有的扩展,它包含了一系列流程控制语句,如`IF...ELSE`...

    sql server 2005示例数据库

    5. **安全性与权限管理**:AdventureWorks允许你实践SQL Server的权限管理,如设置用户角色、赋予不同级别的访问权限,理解如何保护敏感数据,确保系统的安全稳定运行。 6. **备份与恢复**:通过AdventureWorks...

Global site tag (gtag.js) - Google Analytics