0

我遇到的问题是 MySQL 中的 IF 函数没有正确告诉我 ID 是否位于第二个表中。在这里你可以查看我在做什么

http://sqlfiddle.com/#!2/501513/4 '

SELECT c.id AS clientID, IF (e.id, 'yes', 'no') AS hasID
FROM Table1 c LEFT JOIN Table2 e ON (c.id = e.id)
WHERE c.id IN ("123456","H100512","94061","OW59556","OR37615");

如果您注意到值“H100512”和“w76789”都应该说“是”而不是“否”,因为它们位于第二个表中。我注意到,如果我从查询和表中的 id 中删除字母,那么它将正确地说明它是否存在于表中。我在 IF 函数中做错了吗?

4

1 回答 1

3

当然,我认为最好将ids 声明为varchar()并使用单引号而不是双引号来分隔字符串。但是,这些都不是您的问题的原因。

问题是声明:

if(e.id, 'yes', 'no')

在 MySQL 中,这是检查:

if(e.id <> 0, 'yes', 'no')

您可能认为它正在检查NULL. 没有。所以,正在发生的事情是,一个类似的字符串'H100512'被转换为一个整数——它被转换为0未通过测试的字符串。

我认为您应该将查询编写为:

SELECT c.id AS clientID,
       (case when e.id is not null then 'yes' else 'no' end) AS hasID
FROM Table1 c LEFT JOIN
     Table2 e
     ON c.id = e.id
WHERE c.id IN ('123456', 'H100512', '94061', 'OW59556', 'OR37615', 'w76789');

这是明确的,它使用 ANSI 标准条件语句。

于 2013-08-21T22:21:03.357 回答