MySQL查询用户表中所有记录,按ID降序排序,如果用户状态为0(未激活),则注册时间升序,排在结果最后,这个SQL.该怎么写呢?
PHP中文网2017-04-17 15:57:51
假设status=1为激活,0未激活select *from user order by status desc,case status when 1 then id end desc,case status when 0 then created_at end asc;
阿神2017-04-17 15:57:51
select * from user order by id ASC , status ASC , register_time ASC;
这样子是你要的效果咩,如果不符合我再改
迷茫2017-04-17 15:57:51
(从状态 = 1 的用户中选择 按 id desc 排序) union all(从状态 = 0 的用户中按 register_time asc 选择 )