首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >MySQL语法- IF / END IF

MySQL语法- IF / END IF
EN

Stack Overflow用户
提问于 2014-08-23 03:16:39
回答 1查看 55关注 0票数 0

有人能告诉我在正确的语法方面我缺少的是什么吗?我不知道在哪里插入第二端如果结束第一个如果。

谢谢。

代码语言:javascript
复制
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相关联。如果没有,或者,如果有多个,我想离开主块,写以“中止:.”开头的错误消息。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-08-23 03:23:09

关于您的代码的一些小建议:

  • 使用in而不是与or进行比较(更容易阅读)。
  • 您不需要begin/end作为then
  • 字符串常量使用单引号。

结果是这样的:

代码语言:javascript
复制
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的东西,那么existscount(*)更有效。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/25458121

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档