MySQL语法 - IF / END IF

时间:2014-08-23 03:16:39

标签: mysql syntax

有人可以告诉我在正确的语法方面我缺少什么吗?我不知道在哪里插入第二个END IF来结束第一个IF。

感谢。

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相关联。如果没有,或者如果有多个,我想离开主要块并写下以&#34开头的错误消息;中止:..."

1 个答案:

答案 0 :(得分:0)

您的代码的一些小建议:

  • 使用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(*)