MySQL之换座位问题

问题叙述

小美是一所中学的信息科技老师,她有一张 seat 座位表,平时用来储存学生名字和与他们相对应的座位 id。
其中纵列的 id 是连续递增的,小美想改变相邻俩学生的座位。你能不能帮她写一个 SQL query 来输出小美想要的结果呢?
首先先创建seat座位表
MySQL之换座位问题_第1张图片
问题思路:
从最后结果来看就是 :
①id为偶数的需要往前挪
②id为奇数的需要往后挪
③再考虑最后一位是奇数还是偶数,奇数不变(发现偶数的情况已经包含在前面了)

通过 id%2=1 来判断是奇数。
这里需要注意的地方是,最后一位,我们在判断奇数往后挪的时候,是不包含最后一位的。所以在②的时候要限定 id 小于总个数
完整的SQL语句如下:

CREATE TABLE IF NOT EXISTS seat(
id INT PRIMARY KEY,
student VARCHAR(10) NOT NULL
)Engine=Innodb;

INSERT INTO seat VALUES(1,'Abbot');
INSERT INTO seat VALUES(2,'Doris');
INSERT INTO seat VALUES(3,'Emerson');
INSERT INTO seat VALUES(4,'Green');
INSERT INTO seat VALUES(5,'Jeames');

#解决问题
SELECT
(CASE
	WHEN MOD(id,2) = 1 AND id != (SELECT MAX(id) FROM seat) THEN id + 1
	when mod(id,2) = 0 Then id - 1
	ELSE id 
END) AS id ,student
FROM seat 
ORDER BY id;

结果为
MySQL之换座位问题_第2张图片

你可能感兴趣的:(mysql)