首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Mysql按两列排序,如果其中一列大于时间戳

Mysql按两列排序,如果其中一列大于时间戳
EN

Stack Overflow用户
提问于 2013-08-09 01:38:41
回答 2查看 278关注 0票数 0

我在PHP中有这个SQL SELECT:

代码语言:javascript
复制
SELECT * 
  FROM ads 
 ORDER BY ad_sponsored_date DESC, ad_date DESC

我想显示一个广告列表,他们通常是按日期排序,但如果一个是赞助的,那么它会出现在顶部。上面的内容很好地做到了这一点;但是我还需要测试这个ad_sponsored_date是否比时间戳更简单,如果是这样的话,那么只能按照第二个(ad_date)排序,这有可能吗?

就像这样,但我不知道正确的语法:

代码语言:javascript
复制
SELECT * 
  FROM ads 
 ORDER BY (ad_sponsored_date DESC IF ad_sponsored_date > $timestamp, ad_date DESC)
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2013-08-09 01:46:01

这捕获了SQL中的逻辑:

代码语言:javascript
复制
SELECT *
FROM ads
ORDER BY (case when ad_sponsored_date > $timestamp then ad_sponsored_date end) desc,
         ad_date DESC;

然而,我不清楚如何为“框架”的“其他”部分做些什么。

注意:在MySQL中,对于降序排序,空值放在最后,这就是为什么这会将赞助广告放在列表的首位。

票数 1
EN

Stack Overflow用户

发布于 2013-08-09 01:48:09

试一试

代码语言:javascript
复制
SELECT * 
  FROM ads 
  ORDER BY CASE WHEN ad_sponsored_date > '$timestamp'
                THEN ad_sponsored_date 
                ELSE ad_date END DESC

这是SQLFiddle演示

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/18138923

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档