我有以下SQL函数,我从视图中调用
ALTER FUNCTION [dbo].[GetModulesforTesCaseID]
(@TestCaseID numeric(18))
RETURNS VARCHAR(1000)
AS
BEGIN
declare @Modules VARCHAR(1000)
select @Modules = SUBSTRING(
(SELECT ',' + cast (S.MODULENAME as varchar)
FROM MODULE s JOIN EFFMODFORTESTCASE EMTC ON S.MODULEID = EMTC.MODULEID
JOIN TESTCASE TC ON TC.TESTCASEID = EMTC.TESTCASEID
where tc.testcaseid = @TestCaseID
ORDER BY s.MODULENAME
FOR XML PATH('')),2,200000)
if @Modules is null BEGIN
set @Modules = SELECT M.MODULENAME FROM MODULE M JOIN SUBMODULESFORMODULE SFM ON SFM.MODULEID = M.MODULEID
JOIN EFFSUBMODFORTESTCASE ESMTC ON ESMTC.SUBMODULEID = SFM.SUBMODULEID WHERE TESTCASEID = @TestCaseID
END
return @Modules
end
我正在
Msg 156,Level 15,State 1,Procedure GetModulesforTesCaseID,Line 16
附近的语法不正确
关键字“SELECT”
请帮我纠正If条件下的语法错误
答案 0 :(得分:4)
错误是您将值分配给@Modules
内的IF
变量。请尝试这样做(您需要确保该SELECT
的结果只返回一行):
ALTER FUNCTION [dbo].[GetModulesforTesCaseID]
(@TestCaseID numeric(18))
RETURNS VARCHAR(1000)
AS
BEGIN
declare @Modules VARCHAR(1000)
select @Modules = SUBSTRING(
(SELECT ',' + cast (S.MODULENAME as varchar)
FROM MODULE s JOIN EFFMODFORTESTCASE EMTC ON S.MODULEID = EMTC.MODULEID
JOIN TESTCASE TC ON TC.TESTCASEID = EMTC.TESTCASEID
where tc.testcaseid = @TestCaseID
ORDER BY s.MODULENAME
FOR XML PATH('')),2,200000)
if @Modules is null BEGIN
SELECT @Modules = M.MODULENAME
FROM MODULE M
INNER JOIN SUBMODULESFORMODULE SFM
ON SFM.MODULEID = M.MODULEID
INNER JOIN EFFSUBMODFORTESTCASE ESMTC
ON ESMTC.SUBMODULEID = SFM.SUBMODULEID
WHERE TESTCASEID = @TestCaseID
END
return @Modules
end