加入收藏 | 设为首页 | 会员中心 | 我要投稿 莱芜站长网 (https://www.0634zz.com/)- 云连接、建站、智能边缘云、设备管理、大数据!
当前位置: 首页 > 数据库 > MySql > 正文

mysql – SQL – 按语句排序

发布时间:2020-09-26 02:29:35 所属栏目:MySql 来源:互联网
导读:我有这样的表:table A id name email 1 test1 ex@ex.com 2 test2 ex@ex.com 3 test3 ex@ex.com 4 test4 .... 5 test5 .... table B id catA catB year member 1 false true

我有这样的表:

table A
id name   email
1  test1  ex@ex.com
2  test2  ex@ex.com
3  test3  ex@ex.com
4  test4   ....
5  test5   ....

table B
id catA    catB   year member 
1  false   true   2011  2
2  true    false  2011  3
3  fals    true   2010  5

我想获得表A中的每一行并按以下方式对其进行排序:

FIRST,get user 2 (current year,based on table B)
SECOND,get user 3 (current year,based on table B)
after that get users that is in table B
after that get all other users.

我知道我可以拥有特定的sql来获取前两个用户,而且只是
休息.但是,我不能用一个很好的ORDER by语句来获取它们吗?像限制第一顺序语句只是影响第一行… 最佳答案 像这样的东西?

select A.id,A.name,A.email,B.catA,B.catB,B.year
from A
join B on A.id = B.member
ORDER BY B.year DESC,(B.member IS NOT NULL) DESC

首先按表B中的年份字段对所有结果进行排序,这将获得2011年,2010年等等…表B中未列出的任何成员将具有空年份并排序到列表的底部.接下来排序由B.member不为null – mysql将此布尔结果强制转换为整数1或0,可以对其进行排序,因此按降序排序以使所有1(非空B.members)排序优先.

(编辑:莱芜站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读