尽管 MySQL 的 IF EXISTS 子句很受欢迎,但关于其正确实施的问题仍然存在。本文探讨了一个常见问题,即所提供的查询均返回错误消息。
这些错误的主要原因在于尝试在函数之外使用 IF 控制块。此限制会影响两个查询:
IF EXISTS (SELECT * FROM gdata_calendars WHERE `group` = ? AND id = ?) SELECT 1 ELSE SELECT 0
和
IF ((SELECT COUNT(*) FROM gdata_calendars WHERE `group` = ? AND id = ?) > 0) SELECT 1 ELSE SELECT 0
要解决此问题,请将 EXISTS 子句转换为 IF 函数中的子查询:
SELECT IF(EXISTS( SELECT * FROM gdata_calendars WHERE `group` = ? AND id = ?), 1, 0)
此外,布尔值返回为 1 或 0,所以以下查询就足够了:
SELECT EXISTS( SELECT * FROM gdata_calendars WHERE `group` = ? AND id = ?)
以上是MySQL IF EXISTS 子句:为什么我的查询出错?的详细内容。更多信息请关注PHP中文网其他相关文章!