首页  >  问答  >  正文

MySQL查询用户表中所有记录,按ID降序排序,如果用户状态为0(未激活),则注册时间升序,排在结果最后,这个SQL.该怎么写呢

MySQL查询用户表中所有记录,按ID降序排序,如果用户状态为0(未激活),则注册时间升序,排在结果最后,这个SQL.该怎么写呢?

ringa_leeringa_lee2743 天前714

全部回复(3)我来回复

  • PHP中文网

    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;

    回复
    0
  • 阿神

    阿神2017-04-17 15:57:51

    select * from user order by id ASC , status ASC , register_time ASC;这样子是你要的效果咩,如果不符合我再改

    回复
    0
  • 迷茫

    迷茫2017-04-17 15:57:51

    (从状态 = 1 的用户中选择 按 id desc 排序) union all(从状态 = 0 的用户中按 register_time asc 选择

    回复
    0
  • 取消回复