如果一个大于timestamp,则Mysql按两列排序

时间:2013-08-09 01:38:41

标签: php mysql sql sorting conditional

我在PHP中有这个SQL SELECT:

SELECT * 
  FROM ads 
 ORDER BY ad_sponsored_date DESC, ad_date DESC

我想显示一个广告列表,它们通常按日期排序,但如果一个是赞助商,那么它会显示在顶部。以上做得很好;但我还需要测试ad_sponsored_date是否不比时间戳更重要,如果是,那么只能按第二个(ad_date)排序,是否可能?

这样的东西,但我不知道正确的语法:

SELECT * 
  FROM ads 
 ORDER BY (ad_sponsored_date DESC IF ad_sponsored_date > $timestamp, ad_date DESC)

2 个答案:

答案 0 :(得分:1)

这将捕获SQL中的逻辑:

SELECT *
FROM ads
ORDER BY (case when ad_sponsored_date > $timestamp then ad_sponsored_date end) desc,
         ad_date DESC;

但是,我不知道如何处理if的“else”部分。

注意:在MySQL中,NULL值最后用于降序排序,这就是为什么这会将赞助广告放在列表的顶部。

答案 1 :(得分:1)

尝试

SELECT * 
  FROM ads 
  ORDER BY CASE WHEN ad_sponsored_date > '$timestamp'
                THEN ad_sponsored_date 
                ELSE ad_date END DESC

这是 SQLFiddle 演示