有人能告诉我在正确的语法方面我缺少的是什么吗?我不知道在哪里插入第二端如果结束第一个如果。
谢谢。
IF ((SELECT COUNT(*) FROM `item` WHERE `CharID` = argCharID AND (`Name` = 'LBlade' OR `Name` = 'DExe')) != 1) THEN
BEGIN
SET argOutMessage = "Aborted: need 1 LBlade or DExe";
leave main_block;
END;
END IF;我想要完成的是.我想检查一下,在特定的表中是否有“LBlade”或“DExe”与CharID相关联。如果没有,或者,如果有多个,我想离开主块,写以“中止:.”开头的错误消息。
发布于 2014-08-23 03:23:09
关于您的代码的一些小建议:
in而不是与or进行比较(更容易阅读)。begin/end作为then。结果是这样的:
IF ((SELECT COUNT(*)
FROM `item`
WHERE `CharID` = argCharID AND `Name` IN ('LBlade', 'DExe')
) <> 1
)
THEN
SET argOutMessage = 'Aborted: need 1 LBlade or DExe';
leave main_block;
END IF;注意:如果您正在寻找0/1的东西,那么exists比count(*)更有效。
https://stackoverflow.com/questions/25458121
复制相似问题