换座位 sql

示例:

+---------+---------+
|    id   | student |
+---------+---------+
|    1    | Abbot   |
|    2    | Doris   |
|    3    | Emerson |
|    4    | Green   |
|    5    | Jeames  |
+---------+---------+

假如数据输入的是上表,则输出结果如下:

+---------+---------+
|    id   | student |
+---------+---------+
|    1    | Doris   |
|    2    | Abbot   |
|    3    | Green   |
|    4    | Emerson |
|    5    | Jeames  |
+---------+---------+

注意:

如果学生人数是奇数,则不需要改变最后一个同学的座位。

 

select a.id,a.student from(
    select id-1 as id ,student 
    from seat
    where id mod 2 =0
    

    union

    select id,student from seat
    where id mod 2 =1 and id = (select count(*) from seat)

    union
    select id+1 as id,student from seat 
    where id mod 2 = 1 and id != (select count(*) from seat)

)a
order by a.id

 

这里在select之后调用之前查好的结果,就把select的这一大段用括号括上,后面写上as a,就把这一段查好的结果变成了表a,从表a里面调用该怎么查询怎么查询

以及在等于号后面的select必须带括号,不带括号就是报错

 

思路上的总结:

换顺序可以在原来表的基础上进行update,也可以以原来的表作为基础,直接导出一个新的表,新表里面就是所要最终的结果。

分情况的办法,每次在原来的表里面进行查询之后,按照情况每次查询一小部分,然后把它们union在一起。

思维太局限了,每次总是想的是怎么换怎么改,其实只要想那个地方应该填什么就好了,然后怎么把那个地方的值给填上去。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值