以下是表格栏的摘录:
DateCol
…
2009-01-03
2009-01-08
NULL
NULL
2010-01-01
NULL
2010-01-07
NULL
2012-01-01
2012-01-02
2012-01-03
2012-01-04
2012-01-05
2012-01-06
…
当我查询表并要求返回低于2012-01-01的4个值时,我得到以下结果:
2009-01-03
2009-01-08
2010-01-01
2010-01-07
我目前的查询是:
SELECT * FROM myDatabase.MyTable WHERE DateCol < "2012-01-01" ORDER BY DateCol LIMIT 4
如何强制查询返回NULL
值?我正在寻找一个会产生下面输出的声明(请注意,顺序与表中显示的顺序相同)。有一个主键列决定了订单。有没有办法返回值和NULL并“保留”该顺序?
2010-01-01
NULL
2010-01-07
NULL
答案 0 :(得分:6)
使用IS NULL
同时获取NULL
值
SELECT *
FROM myDatabase.MyTable
WHERE DateCol < "2012-01-01" OR DateCol IS NULL
ORDER BY (CASE WHEN DateCol IS NULL then 1 ELSE 0 END)
LIMIT 4