MySQL语法-IF/END IF

MySQL语法-IF/END IF,mysql,syntax,Mysql,Syntax,有人能告诉我在正确的语法方面我缺少什么吗?我不知道在哪里插入第二个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 m

有人能告诉我在正确的语法方面我缺少什么吗?我不知道在哪里插入第二个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;

我试图实现的是……我想检查特定表中是否有与CharID关联的“LBlade”或“DExe”。如果没有一个,或者如果有多个,我想离开主块并编写错误消息,以Aborted开头:…

对代码的一些小建议:

在中使用,而不是与比较或更易于阅读。 你不需要开始/结束。 对字符串常量使用单引号。 结果是这样的:

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*更有效*

从这里删除最后一个'DExe',我想您应该通过hhi@Satya,如果我这样做,不幸的是,我得到一个语法错误,命令无法运行1064-near'然后BEGIN…'这是我在选择之前错过了开头括号的一个错误