首页 > 代码库 > 自定义函数执行动态sql语句
自定义函数执行动态sql语句
--函数中不能调用动态SQL,使用用存储过程吧。如果还要对函数做其他操作,换成存储过程不方便,可以考虑把其他操作一起封装在存储过程里面。如:
create
proc [dbo].[FUN_YSCL_GetSpvalue]
@FormID
VARCHAR
(200)
AS
BEGIN
DECLARE
@TableID
VARCHAR
(20)
SELECT
@TableID = tb.vcTableID
FROM
tG10Money tm
LEFT
JOIN
tG10Tables tb
ON
tm.iFormType = tb.ID
WHERE
vcFormID = @FormID
DECLARE
@strSQL NVARCHAR(2000)
SET
@strSQL =
‘‘
SET
@strSQL +=
‘ SELECT ‘
SET
@strSQL +=
‘@spvalue=http://www.mamicode.com/tb.SPValue‘
SET
@strSQL +=
‘ FROM ‘
+ @TableID +
‘ tb‘
SET
@strSQL +=
‘ RIGHT JOIN ( SELECT DISTINCT‘
SET
@strSQL +=
‘ FormID ,‘
SET
@strSQL +=
‘ MAX(WFNodeIndex) AS maxnode‘
SET
@strSQL +=
‘ FROM tFS1001‘
SET
@strSQL +=
‘ WHERE RowType = 1‘
SET
@strSQL +=
‘ GROUP BY WFID ,‘
SET
@strSQL +=
‘ FormID‘
SET
@strSQL +=
‘ ) maxnode‘
SET
@strSQL +=
‘ ON tb.FormID = maxnode.FormID‘
SET
@strSQL +=
‘ AND tb.WFNodeIndex = maxnode.maxnode‘
SET
@strSQL +=
‘ WHERE tb.FormID= ‘
‘‘
+@FormID+
‘‘
‘‘
DECLARE
@spvalue
VARCHAR
(20)
EXEC
sp_executesql @strSQL,N
‘@spvalue VARCHAR(20) out‘
,@spvalue
OUTPUT
select
FormID,@spvalue
FROM
tFormMoney
END
自定义函数执行动态sql语句
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。