目前我正在我的声明中做一个非常基本的orderderby。

SELECT * FROM tablename WHERE visible=1 ORDER BY position ASC, id DESC

这样做的问题是,“position”的NULL条目被视为0。因此,所有位置为NULL的条目都出现在位置为1,2,3,4的条目之前。例如:

NULL, NULL, NULL, 1, 2, 3, 4

有没有办法实现以下排序:

1, 2, 3, 4, NULL, NULL, NULL.

当前回答

这工作得很好:

SELECT * FROM tablename ORDER BY position = 0, position ASC;

position
1 
2
3
0
0

其他回答

空最后

SELECT * FROM table_name ORDER BY id IS NULL, id ASC

类似的

SELECT * FROM tablename where visible=1 ORDER BY COALESCE(position, 999999999) ASC, id DESC

将999999999替换为该字段的最大值

SELECT * FROM tablename WHERE visible=1 ORDER BY CASE WHEN `position` = 0 THEN 'a' END , position ASC

你可以用不同的值交换NULL实例来排序它们的第一个(比如0或-1)或最后一个(一个大数字或字母)…

SELECT field1, IF(field2 IS NULL, 9999, field2) as ordered_field2
  FROM tablename
 WHERE visible = 1
 ORDER BY ordered_field2 ASC, id DESC

你可以在ORDER BY语句中合并null值:

select * from tablename
where <conditions>
order by
    coalesce(position, 0) ASC, 
    id DESC

如果希望null在底部排序,请尝试coalesce(position, 100000)。(使第二个数字大于db中所有其他位置的数字。)