Heim > Backend-Entwicklung > PHP-Tutorial > 请教一个查询

请教一个查询

WBOY
Freigeben: 2016-06-23 13:46:28
Original
844 Leute haben es durchsucht

表里有三个字段  id,create_at,status  【id 为编号,自增  ,create_at 为创建时间  ,status 为状态】

我想做的是 先按 状态升序排序, 当状态值为  2 时,按create_at 降序,状态值为 3 时按create_at 升序。

网上搜索 过,看到了case when 的写法。 自己尝试过,没整出来,还请各位高手帮忙,非常感谢。


回复讨论(解决方案)

可以把查询的order 写成一个变量  根据status去给order 赋值

可以把查询的order 写成一个变量  根据status去给order 赋值



那么问题来了,究竟是怎么写叱?


可以把查询的order 写成一个变量  根据status去给order 赋值



那么问题来了,究竟是怎么写叱?


就是拼接where条件  



可以把查询的order 写成一个变量  根据status去给order 赋值



那么问题来了,究竟是怎么写叱?
就是拼接where条件  


一 非常感谢你。
二 希望你以后在帮助人的时候,可以给出更具体方法。 我自己感觉这个例子,字段已准备得足够简单的。
谈处理方法 ,我自己也了解一些,有时候,就是一些语法,等q/a 问题卡住了,希望有更直接的帮助。
三 刚才自己把这个问题给折腾出来了。我是这样解决的。

SELECT *  FROM table_name 
ORDER BY STATUS ASC, CASE STATUS WHEN 2 THEN create_at ELSE -create_at END DESC;

.... order by status, case when status=2 then create_at end desc, case when  status=3 then create_at end

我喜欢这样写
.... order by status, if(status=2,create_at,‘’) desc, if(status=3,create_at,‘’)

.... order by status, case when status=2 then create_at end desc, case when  status=3 then create_at end

我喜欢这样写
.... order by status, if(status=2,create_at,‘’) desc, if(status=3,create_at,‘’)



非常感谢 ,很有收获。
Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage