每日SQL一练#20231028,交换两行的值

517 阅读1分钟

今天也是leetcode,主要考察的是用SQL交换两行的值,准确来说是交换连续的两行的值。

题干

表: Seat

+-------------+---------+
| Column Name | Type    |
+-------------+---------+
| id          | int     |
| student     | varchar |
+-------------+---------+
id 是该表的主键(唯一值)列。
该表的每一行都表示学生的姓名和 ID。
id 是一个连续的增量。

编写解决方案来交换每两个连续的学生的座位号。如果学生的数量是奇数,则最后一个学生的id不交换。

按 id 升序 返回结果表。

查询结果格式如下所示。

示例 1:

输入: 
Seat 表:
+----+---------+
| id | student |
+----+---------+
| 1  | Abbot   |
| 2  | Doris   |
| 3  | Emerson |
| 4  | Green   |
| 5  | Jeames  |
+----+---------+
输出: 
+----+---------+
| id | student |
+----+---------+
| 1  | Doris   |
| 2  | Abbot   |
| 3  | Green   |
| 4  | Emerson |
| 5  | Jeames  |
+----+---------+
解释: 请注意,如果学生人数为奇数,则不需要更换最后一名学生的座位。

测试数据

drop table if exists Seat;
create table Seat(id int,student varchar(255));
insert into Seat(id,student) values(1,'Abbot'),(2,'Doris'),(3,'Emerson'),(4,'Green'),(5,'Jeames');

解析

交换两行的值,换句话来说,就是交换他们的id。 这里的需求是交换两个连续的id的值,且后续还需要判断最后一个id是否为奇数,那么可以通过除2求余的方式来处理,求余等于1则为奇数,则加一,否则减一,如果等于奇数且为最后一个id则不动。

解题

select
    case
    when mod(tb1.id, 2)=1 and tb1.id!=tb2.cnt then tb1.id+1
    when mod(tb1.id, 2)=1 and tb1.id=tb2.cnt then tb1.id
    else tb1.id-1 end as `id`,
    student
from Seat as tb1, (select count(id) as cnt from Seat) as tb2
order by id
;

image.png