当前位置:首页 > 系统运维 > 正文内容

修改SQL Server 2005数据库执行环境

a8116255316年前 (2010-06-30)系统运维10

下面的文章主要介绍的是正确修改SQL Server 2005数据库执行环境,我们大家都知道执行环境是SQL Server数据库中设定用户权限的认证方式,区中包括,当您登录到SQL Server的时候,登录账户就被赋予了一定的权限。

其中可能包括登录的功能、访问数据库以及在数据库中执行某些操作的功能。

SQL Server 2005包含了EXECUTE AS语句,通过使用EXECUTE AS语句,您可以为批处理和过程转换执行环境,这样,调用该批处理或过程的用户就可以使用不同的权限来操作了。

所有权链

在我正式讲解SQL Server 2005中执行环境的问题之前,先来简单地说说所有权链的工作原理。

当用户执行一个存储过程的时候(假定该用户拥有执行该存储过程的权限),SQL Server将该存储过程的所有者与这个存储过程所涉及到的对象的所有者进行对比,假如他们的所有者相同,那么就不必对这些引用对象的权限进行评估了。

所以,假如用户Tim获得了存储过程usp_ProcedureChAIn的权限,而usp_ProcedureChain存储过程的所有者是dbo,那么,假如dbo还同时拥有usp_ProcedureChain所调用的其他存储过程,那么Tim在执行这个存储过程的时候就不会出现错误。

执行环境的转换

在SQL Server 2000中,您可以使用SETUSER命令来模拟SQL用户的执行环境,但问题在于,只有系统管理员或者数据库的所有者才能使用这个命令,而且windows账户也不能使用该命令。

在SQL Server 2005中,EXECUTE AS语句可以替代SETUSER来改变存储过程、触发器、批处理或者函数的执行环境。假如执行环境变成了另外一个用户,那么SQL Server将检查该用户的权限。假如您需要在创建或修改一个存储过程或函数的时候指定EXECUTE AS语句,您需要具备IMPERSONATE的权限,以及创建该对象的权限。

实例

正如我刚才所介绍的一样,改变存储过程的执行环境非常有用,接下来我将通过实例来讲解如何实现这一功能。在这个例子中,您会看到如何使用EXECUTE AS将没有确切权限的使用者模拟为所有者对表格进行插入操作。

在之一行语句中,我使用了REVERT命令,这样,您就可以完整地返回到例子中,而不必担心需要清除任何对象。

REVERT  go  

在下面的代码的第七行,我使用了清除语句,这样可以检查我在随后的例子中要使用的对象是否已经存在,假如已经存在,就将其清除。

IF OBJECT_ID('usp_InsertMyTable','P')>0  DROP PROCEDURE usp_InsertMyTable  GO  IF OBJECT_ID('TableOwnerSchema.MyTable','U')>0  DROP TABLE TableOwnerSchema.MyTable  GO  IF EXIstS  (SELECT * FROM sys.schemas WHERE name = N'TableOwnerSchema')  DROP SCHEMA [TableOwnerSchema]  IF EXISTS  (SELECT * FROM sys.database_principals WHERE name = N'BaseUser')  DROP USER BaseUser  IF EXISTS  (SELECT * FROM sys.server_principals WHERE name = N'BaseUser')  DROP LOGIN BaseUser  IF EXISTS  (SELECT * FROM sys.database_principals WHERE name = N'TableOwner')  DROP USER TableOwner  IF EXISTS  (SELECT * FROM sys.server_principals WHERE name = N'TableOwner')  DROP LOGIN TableOwner  

以下的脚本语句创建了两个登录名和数据库的用户账户,注意,CHECK_EXPIRATION和CHECK_POLICY语句,这两条语句是SQL Server 2005中新出现的。这些语句告诉SQL Server不要对这个用户账户强制执行密码截止期限策略,同时也不要进行任何类型的密码策略检查,对于强制安全策略而言,这些是非常有效的 *** 。

CREATE LOGIN [BaseUser] WITH PASSWORD=N'baseuser',  DEFAULT_DATABASE=[TRS],  CHECK_EXPIRATION=OFFCHECK_POLICY=OFF GO  CREATE USER [BaseUser] FOR LOGIN [BaseUser]  GO  CREATE LOGIN [TableOwner] WITH PASSWORD=N'tableowner',  DEFAULT_DATABASE=[TRS],  CHECK_EXPIRATION=OFFCHECK_POLICY=OFF GO  CREATE USER TableOwner FOR LOGIN TableOwner  GO  

在SQL Server 2005中,模式不再是和数据库用户相同的事情了,对于所包含的对象而言,它处于完全不同的名称空间。用户和模式的分离是SQL Server 2005中的一大进步,这样做使对象的所有权可以分离,而且比SQL Server 2000更易于管理,以下的语句创建了我们将要使用的数据库模式:

CREATE SCHEMA [TableOwnerSchema] AUTHORIZATION [TableOwner]  GO  Now I enable logins so they can be used:  ALTER LOGIN [TableOwner] ENABLE  ALTER LOGIN [BaseUser] ENABLE  GO  GRANT CREATE TABLE TO TableOwner  GO  

首先,我使用了EXECUTE AS命令,我将当前的执行环境设定为TableOwner,在运行了这个命令之后,所有的权限评估将以TableOwner运行,而以前的系统管理员权限将不再适用。

EXECUTE AS USER = 'TableOwner' GO  

运行这个语句就能够表明现在的执行环境是TableOwner:

SELECT SESSION_USER  GO  

这个脚本将在TableOwnerSchema的模式中创建一个名为MyTable的表格,因为我已经赋予了该用户CREATE TABLE 的权限,所以TableOwner可以执行这条语句。

CREATE TABLE TableOwnerSchema.MyTable  (  Field1 INT  )  GO  

当我运行REVERT语句的时候,可以在执行环境链中回退一步,在SQL Server 2005中,执行环境是可以嵌套的,所以假如您在同一个数据库连接中有很多用户在运行,您可能需要多次执行该语句以返回到原始的登录环境。

REVERT  GO  SELECT SESSION_USER  GO  

现在我要对新的表格进行快速选择以确认它的存在:

SELECT * FROM TableOwnerSchema.MyTable  GO  

以下的脚本创建了一个过程可以插入新的TableOwnerSchema.MyTable表格,注意我在过程定义中使用了WITH EXECUTE AS 'TableOwner'语句,这意味着该过程被执行的时候,它将在TableOwner的执行环境中被执行。

CREATE PROCEDURE usp_InsertMyTable  WITH EXECUTE AS 'TableOwner'  AS  BEGIN  INSERT INTO TableOwnerSchema.MyTable(Field1)VALUES(8)  END  GO  

我还可以将执行权限赋予一个用户账户,在这种情况下,我使用以前创建的名为BaseUser的用户。

GRANT EXEC ON usp_InsertMyTable TO BaseUser  GO  

接下来,我将执行环境转换为BaseUser并尝试运行存储过程:

EXECUTE AS USER = 'BaseUser' GO  EXEC usp_InsertMyTable  GO  

现在我可以向TableSchema.MyTable表格中添加记录了,因为在这个过程中TableOwner允许我这样做,而BaseOwner并没有明确的权限可以向该表格添加记录,所以该用户的任何尝试都会导致错误的发生。为了演示这个问题,可以运行以下的脚本,该脚本改变了我们刚才的过程,改为运行在调用者的执行环境中。

REVERT  GO  ALTER PROCEDURE usp_InsertMyTable  AS  BEGIN  INSERT INTO TableOwnerSchema.MyTable(Field1)VALUES(8)  END  GO  EXECUTE AS USER = 'BaseUser' GO  EXEC usp_InsertMyTable  GO  REVERT  

开发者和数据库管理员会发现在执行修改SQL Server 2005数据库执行环存储过程的时候转换权限非常有用,尤其是您处理TRUNCATE TABLE语句的时候,这个 *** 能帮上大忙,因为TRUNCATE TABLE并没有可以指定的权限。您可以将权限赋予将要进行截取表格操作的用户,然后在操作结束的时候再将原有的权限设定恢复就可以了。

扫描二维码推送至手机访问。

版权声明:本文由2345好导航站长资讯发布,如需转载请注明出处。

本文链接:http://www.2345hao.cn/blog/index.php/post/21376.html

分享给朋友:

“修改SQL Server 2005数据库执行环境” 的相关文章

windows 7鼠标停顿怎么办?windows 7 usb鼠标停顿的原因以及解决

windows 7鼠标停顿怎么办?windows 7 usb鼠标停顿的原因以及解决

很多使用Windows 7系统的朋友都想小编反应,假如暂停使用电脑,鼠标会出现停顿现象,这是怎么回事呢 该怎么解决呢 下面就和小编一起去看下Windows 7 usb鼠标停顿的解决方法吧。 由于Windows 7系统中有一项USB选择性暂停造成的。这项设置主要为了节电,当他检测到用户没有对系统进行...

windows 7/8.1正在启动windows时间长的解决方法

windows 7/8.1正在启动windows时间长的解决方法

正在启动windows时间长怎么办 小编带来了Windows 7/8.1正在启动windows时间长解决方法,假如有朋友在安装完Windows系统之后一直停留在“正在启动windows”的话,不妨试一试下文的方法哦~ 原因:Windows 7/8.1不完全支持UEFI,需要CSM(Comp...

windows 7系统的电脑发出嘟嘟嘟的声音该怎么解决?

windows 7系统的电脑发出嘟嘟嘟的声音该怎么解决?

在某些电脑中,机器内部蜂鸣器与系统的声音输出方案是相关联的,这样一来会导致当系统输出声音时,即使电脑没有连接外部音响或耳机,也会通过内置蜂鸣器发出“嘟嘟哔哔”的声音。这个问题主要出现在Windows 7电脑中,假如你的电脑恰好遇到了这样的问题,可参考下面的方法来解决: 1、在桌面“计算机”图标上右...

各个都很实用:windows 7系统电脑日常小技巧

各个都很实用:windows 7系统电脑日常小技巧

在使用Windows 7的时候很多用户对于系统的很多功能并不是很了解,也正是因为这样的不了解导致很多用户在使用Win 之后并不能体验Windows 7的功能便携和强大功能,导致很多用户对于Windows 7的认识还是比较模糊,不过为了让更多的朋友了解Windows 7的特点和便携应用,今天就为大家汇...

Win 7系统中其他声音正常但酷狗音乐没声音怎么回事

Win 7系统中其他声音正常但酷狗音乐没声音怎么回事

故障现象: Windows 7酷狗软件无声音,系统声音正常。 原因分析: 1. 查看酷狗软件设置 2. 查看系统设置 解决方案: 1. Windows 7操作方法 如图:查看是否处于禁音状态   Windows 7系统声音正常酷狗音乐无声音 2. 查看设置音频输出是否...

解决windows 7无法将程序锁定到任务栏或附到开始菜单的方法

解决windows 7无法将程序锁定到任务栏或附到开始菜单的方法

出现该问题的原因是由于使用第三方优化软件消除快捷方式的小箭头引起的。 1、在开始搜索框中键入“regedit”,按回车键打开注册表编辑器。 2、依次定位到以下分支:HKEY_CLASSES_ROOTlnkfile。 3、在lnkfile项上鼠标右键单击“新建”——“字符串值”。...