Conditional ORDER BY depending on column values

别来无恙 提交于 2019-12-01 18:40:37

I'd say the BEST way to do this is in a single query is a CASE statement...

SELECT TOP 1 FROM ... ORDER BY 
    (CASE WHEN column1 IS NULL THEN column2 ELSE column1 END) 

You could use a COALESCE function to turn nullable columns into orderby friendly values.

 SELECT   CAST(COALESCE(MyColumn, 0) AS money) AS Column1 
 FROM     MyTable
 ORDER BY Column1;

I used in Firebird (columns are numeric):

ORDER BY CASE <condition> WHEN <value> THEN <column1>*1000 + <column2> ELSE <column3>*1000 + <column4> END
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!