小美是一所中学的信息科技老师,她有一张 seat 座位表,平时用来储存学生名字和与他们相对应的座位 id。

其中纵列的 id 是连续递增的

小美想改变相邻俩学生的座位。

你能不能帮她写一个 SQL query 来输出小美想要的结果呢?

示例:

+---------+---------+
|    id   | student |
+---------+---------+
|    1    | Abbot   |
|    2    | Doris   |
|    3    | Emerson |
|    4    | Green   |
|    5    | Jeames  |
+---------+---------+
假如数据输入的是上表,则输出结果如下:

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

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

SQL代码:

select 
    IF(mod(id,2)=0,id-1,IF(id=(select max(id) from seat),id,id+1)) as id,student
from seat
order by id

今天学到了一个IF函数,该函数的用法是如下:

IF(true,1+1,1+2),输出2

IF(false,1+1,1+2),输出3

该函数的执行机制是判断第一个参数是否为真,若为真则返回第二个参数,若不为真则返回地三个参数,该题则用了2个IF嵌套