选择显示字体大小

权限管理


14.4.1 权限管理简介
用户在登录到sql server 之后,其安全账号(用户账号)所归属的nt 组或角色所被授予的权限决定了该用户能够对哪些数据库对象执行哪种操作以及能够访问、修改哪些数据。在sql server 中包括两种类型的权限,即对象权限和语句权限。

(1) 对象权限
对象权限总是针对表、视图存储过程而言,它决定了能对表、视图存储过程执行哪些操作(如update、 delete、 insert、 execute)。如果用户想要对某一对象进行操作,其必须具有相应的操作的权限。例如,当用户要成功修改表中数据时,则前提条件是他已经被授予表的update 权限。
不同类型的对象支持不同的针对它的操作例,如不能对表对象执行execute 操作。我们将针对各种对象的可能操作列举如表14-1 所示:

注意:reference充许在grant、deny、revoke语句中向有外键参照表中插入一行数据。

(2) 语句权限
语句权限主要指用户是否具有权限来执行某一语句,这些语句通常是一些具有管理性的操作,如创建数据库、表、存储过程等。这种语句虽然仍包含有操作如(create)的对象,但这些对象在执行该语句之前并不存在于数据库中如创建一个表,在createtable 语句未成功执行前数据库中没有该表),所以将其归为语句权限范畴。表14-2是所有的语句权限清单。



各参数含义说明如下:

????????

revoke和deny语法格式与grant语法格式一样。


14.4.2 利用sql server enterprise manager 管理权限
在sql server 中通过两种途径可实现对语句权限和对象权限的管理,从而实现对用户权限的设定。这两种途径分别为面向单一用户和面向数据库对象两种权限设置。

1 面向单一用户的权限设置
在sql server enterprise manager 其执行步骤为:
(1) 启动sql server enterprise manage, 登录到指定的服务器
(2) 展开指定的数据库,然后单击users 图标,此时在右窗格中将显示数据库所有用户。
(3) 在数据库用户清单中选择要进行权限设置的用户,右击用户名,然后在弹出 菜单中选择properties, 弹出database user properties 对话框,如图14-6 所示。

(4) 在database user properties 对话框中单击permission 按钮,弹出如图14-7 所示的database user properties 对话框,在该对话框中进行对象权限设置。

(5) 单击确定,完成权限设置。 在图14-6 的对话框中,如果在database role membership 选项栏中选择任何一个数 据库角色(在缺省条件下,任何数据库用户都至少是public 角色),实际上就完成了 数据库用户语句权限的设置。因为对于这些数据库固定角色,sql server 已定义了其 具有哪些语句权限,例如db_owner 具有执行create database 的语句权限(关于 角色将在下节作详细介绍)。

在图14-7 的用户权限设置对话框中,显示了用户当前数据库中的所有对象,其中 包括表、视图存储过程等,同时也给出针对该对象能够进行哪些操作。通过单击其 中的空白方格来完成权限设置。当空白方格内为对号时,表示执行了grant 语句, 即用户能够对该对象执行相应的操 作;当空白方格内为错号时,表示执 行了deny 语句,即禁止对该对象 的相应操作。
通过点击“list only objects with permissions for this user”,将列出该 用户有权访问的所有数据库对象以及 详细的访问权限设置信息。
在图14-7 的用户权限设置对话 框 ,可以单击column 按钮,在打开 的column permissions 对话框中来决 定用户对哪些列具有哪些权限。如图 14-8 所示。


2 面向数据库对象的权限设置
在sql server enterprise manager 其执行步骤为:
(1)启动sql server enterprise manager, 登录到指定服务器
(2)展开指定的数据库,从中选择用户对象(表、视图存储过程)。
(3) 在右格对话框中选择要进行权限设置的对象,右击该对象。
(4) 在弹出菜单中选择all tasks, 选择manage permission, 此时弹出objectproperties 对话框。如图14-9 所示。

(5) 设置权限,单击确定。

object properties 对话框与database user properties 对话框极为相似,在database user properties 对话框,我们为某一用户设置其对当前数据库所有对象的访问权限;在object properties 对话框中,我们为某一数据库对象设置当前数据库所有用户对其的访问权限。
通过点击“list only user/db roles with permissions on this object”,可以列出所有对该对象具有访问权限的数据库用户或角色。

  


 


关键字 本文所属关键字

相关 与本文相关文章

分类 所有文章关键字导航

源码编程相关

Java   Asp   PHP   .Net   XML   C/C++   CGI   VB   Jsp   J2ee   J2se   J2me   EJB   Servlet   Tomcat   Resin   Struts   Weblogic   Eclipse   ANT   GUI   JMS   Web servise   IDEA   Webphere   Hibernate   Spring   Jboss   Applet   Swing   Socket   Javamail   Perl   Ajax   P2P   安全   模式   框架   测试   开源   游戏

SQL数据库相关

My-SQL   Ms-SQL   Access   DB2   Oracle   Sybase   SQLserver   索引   存储过程   加密   数据库   分页   视图  

手机无线相关

3G   Wap   CDMA   GRPS   GSM   IVR   彩信   短信   无线   增值业务

网页设计制作相关

HTML   CSS   网页配色   网页特效   Javascript   VBscript   Dreamweaver   Frontpage   JS   Web   网站设计

网站建设推广相关

建站经验   网站优化   网站排名   推广   Alexa

操作系统/服务器相关

Windows XP   Windows 2000   Windows 2003   Windows Me   Windows 9.x   Linux   UNIX   注册表   操作系统   服务器   应用服务器

图形图像多媒体相关

Photoshop   Fireworks   Flash   Coreldraw   Illustrator   Freehand   Photoimpact   多媒体   图形图像

标准 网站致力的规范

Valid CSS!

无不良内容,无不良广告,无恶意代码

Valid XHTML 1.0 Transitional

creativecommons