Mysql: select * from table where col IN (null, “”)

2019-03-22 21:49发布

is its somehow possible to do a select for empty strings and NULL values in Mysql without using or?

this:

   select * from table where col IN (null, "");

doesnt work, it ignores the null (or possibly matches it with the string 'null'

thanks, P.V. Goddijn

标签: mysql null
1条回答
放我归山
2楼-- · 2019-03-22 22:16
SELECT  *
FROM    mytable
WHERE   COALESCE(col, '') = ''

Note, however, than OR query will be much more efficient if the column is indexed:

SELECT  *
FROM    mytable
WHERE   col = '' OR col IS NULL

This will use ref_or_null access path on the index.

If you need to select from a list of values along with NULLs, just put all not-null values into the list and add a single OR IS NULL condition:

SELECT  *
FROM    mytable
WHERE   col IN ('val1', 'val2', 'val3') OR col IS NULL

This will use an index on col as well.

查看更多
登录 后发表回答