码迷,mamicode.com
首页 > 数据库 > 详细

Sqlserver数据库中,跨权限执行语句

时间:2018-08-07 00:36:26      阅读:164      评论:0      收藏:0      [点我收藏+]

标签:http   style   tps   begin   alt   from   server   self   span   

原文:Sqlserver数据库中,跨权限执行语句

问题来源:最近有同事需要执行批量删除语句。根据他提供的业务需求,推荐他使用“TRUNCATE TABLE”语句。但使用该语句需要 ALTER权限,这与执行用户的角色不符。

解决办法:使用EXECUTE AS语句修改执行权限。代码如下:

ALTER PROCEDURE [dbo].[sp_TruncateTable] 
    @TableName varchar(200) 
    WITH EXECUTE AS SELF
AS 
BEGIN 
    --打印出当前执行上下文用户
    SELECT  nt_username, loginame 
    FROM sys.sysprocesses 
    WHERE spid = @@SPID

    SET NOCOUNT ON; 
    DECLARE @TruncateSql nvarchar(2000);
    SET @TruncateSql = TRUNCATE TABLE  + @TableName 
    EXEC (@TruncateSql) 
END

 

通过打印出来的loginame可以看出,执行用户信息已经被修改。

Sqlserver数据库中,跨权限执行语句

标签:http   style   tps   begin   alt   from   server   self   span   

原文地址:https://www.cnblogs.com/lonelyxmas/p/9434138.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!