Possible to use SQL to sort by date but put null dates at the back of the results set?

前端 未结 4 771
萌比男神i
萌比男神i 2021-01-31 01:53

I have a bunch of tasks in a MySQL database, and one of the fields is \"deadline date\". Not every task has to have to a deadline date.

I\'d like to use SQL to sort the

相关标签:
4条回答
  • 2021-01-31 02:16

    Here's a solution using only standard SQL, not ISNULL(). That function is not standard SQL, and may not work on other brands of RDBMS.

    SELECT * FROM myTable
    WHERE ...
    ORDER BY CASE WHEN myDate IS NULL THEN 1 ELSE 0 END, myDate;
    
    0 讨论(0)
  • 2021-01-31 02:16

    The easiest way is using the minus operator with DESC.

    SELECT * FROM request ORDER BY -date DESC

    In MySQL, NULL values are considered lower in order than any non-NULL value, so sorting in ascending (ASC) order NULLs are listed first, and if descending (DESC) they are listed last.

    When a - (minus) sign is added before the column name, NULL become -NULL.

    Since -NULL == NULL, adding DESC make all the rows sort by date in ascending order followed by NULLs at last.

    0 讨论(0)
  • 2021-01-31 02:31
    SELECT * FROM myTable
    WHERE ...
    ORDER BY ISNULL(myDate), myDate
    
    0 讨论(0)
  • 2021-01-31 02:33
    SELECT foo, bar, due_date FROM tablename
    ORDER BY CASE ISNULL(due_date, 0)
    WHEN 0 THEN 1 ELSE 0 END, due_date
    

    So you have 2 order by clauses. The first puts all non-nulls in front, then sorts by due date after that

    0 讨论(0)
提交回复
热议问题