使用SQL Server 7.0建立一个安全的数据库


永远不要给用户直接访问表的权限。如果你希望让用户使用交互式工具如Microsoft Acess 2000来访问数据库,可以只给他们访问视图和存储过程的权限,而不是对表的直接访问权限。如果存储过程的拥有者是“dbo”,而且存储过程所引用的表和视图的拥有者也都是“dbo”,给予用户对存储过程的执行(EXECUTE)权限就足够了。这样就根本不用检查对表的访问权限了。

你还可以使用其它安全特性,比如通过在存储过程中加入商业逻辑来控制哪些字段或行能够被访问。视图是阻止用户直接访问表的另一种途径。与存储过程的区别是,你可以为视图授予SELECT、INSERT、UPDATE或DELETE权限,而存储过程则只能授予EXECUTE权限。

还有一件需要注意的事情是,如果你在另外一个数据库中执行SELECT语句,数据库对象拥有者的的链式关系仍然适用。比如说,在由SQL Server登录名“sa”所拥有的pubs数据库中,你就不能执行跨表查询连接至被一个NT登录名所拥有的数据库中,即使两个登录名都是“sysadmin”角色的成员。如果你希望连接来自3个不同数据库的表,那么这3个数据库的拥有者应该是同一个帐号。如果需要的话你可以使用存储过程“sp_changedbowner”来改变数据库的拥有者。

本文作者:



相关阅读:
Javascript 构造函数,公有,私有特权和静态成员定义方法
HTML tabIndex属性
Linux服务器安全之四种攻击级别的防范手段
Linux下malloc/free与new/delete的区别
内核升级后 出现initramfs错误问题解决
CSS 网页布局中文排版的9则技巧
JavaScript 高级语法介绍
3Z版基于jquery的图片复选框(asp.net+jquery)
vbs得没公开对象
PHP提取数据库内容中的图片地址并循环输出
使用Microsoft SQL Server 2005 构建更好的应用程序
css设置z-index 失效的解决方法
在Linux系统下检测U盘是否已连接的方法
HTML网页列表标记学习教程
快速导航

Copyright © 2016 phpStudy |