在SQL触发器中,字段为动态字段变量,获取动态字段更新前/后的值 30
--获取动态字段DECLARE@COLUMNS_NAMENVARCHAR(50)DECLARE@IINTSELECT@COLUMNS_NAME=[name]FROMsys...
--获取动态字段
DECLARE @COLUMNS_NAME NVARCHAR(50)
DECLARE @I INT
SELECT @COLUMNS_NAME = [name] FROM syscolumns WHERE ID = OBJECT_ID('表名,'U') AND COLID = @I --能将第I个字段名赋值到@COLUMNS_NAME
DECLARE @D_VALUE NVARCHAR(1000)
DECLARE @S NVARCHAR(1000)
SET @S = 'SELECT @EXSQL= '+@COLUMNS_NAME+' FROM DELETED'
EXEC SP_EXECUTESQL @S,N'@EXSQL NVARCHAR(1000) OUTPUT',@EXSQL=@D_VALUE OUTPUT
--想以@COLUMNS_NAME作为字段名,找DELETED表中的值,但是根本无法执行,导致原来的表也无法更新
有没有什么办法?
触发类型FOR UPDATE
如果采用降低兼容级别的做法,是否可取? 展开
DECLARE @COLUMNS_NAME NVARCHAR(50)
DECLARE @I INT
SELECT @COLUMNS_NAME = [name] FROM syscolumns WHERE ID = OBJECT_ID('表名,'U') AND COLID = @I --能将第I个字段名赋值到@COLUMNS_NAME
DECLARE @D_VALUE NVARCHAR(1000)
DECLARE @S NVARCHAR(1000)
SET @S = 'SELECT @EXSQL= '+@COLUMNS_NAME+' FROM DELETED'
EXEC SP_EXECUTESQL @S,N'@EXSQL NVARCHAR(1000) OUTPUT',@EXSQL=@D_VALUE OUTPUT
--想以@COLUMNS_NAME作为字段名,找DELETED表中的值,但是根本无法执行,导致原来的表也无法更新
有没有什么办法?
触发类型FOR UPDATE
如果采用降低兼容级别的做法,是否可取? 展开
1个回答
2012-11-26
展开全部
SET @S = 'SELECT @EXSQL= '+@COLUMNS_NAME+' FROM DELETED'?
更多追问追答
追问
因为曾经尝试过,直接执行
SELECT @D_VALUE =@COLUMNS_NAME FROM DELETED
但是@D_VALUE 只能获取@COLUMNS_NAME的值,并不是SELECT结果的值。
所以换了一个想法,想用字符串(即:SET @S = 'SELECT @EXSQL= '+@COLUMNS_NAME+' FROM DELETED')查询然后输出变量,结果还是不行
追答
会不会是from updated呢?
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询