示例:
+---------+---------+
| 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在一起。
思维太局限了,每次总是想的是怎么换怎么改,其实只要想那个地方应该填什么就好了,然后怎么把那个地方的值给填上去。