SQL-每日一题【626.换座位】

题目

表: Seat

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

按 id 升序 返回结果表。

查询结果格式如下所示。

示例 1:

解题思路

前置知识

MySQL 的 MOD() 函数是取模运算的函数,它返回两个数相除的余数。其语法如下:

sql 复制代码
MOD(dividend, divisor)

其中,dividend 和 divisor 都是数值表达式,dividend 除以 divisor 并返回余数。

注意,如果除数为 0,则 MOD() 函数返回 NULL,而不会引发错误。

让我们一起来看一下这道题吧!

1.题目要求我们交换每两个连续的学生的座位号。如果学生的数量是奇数,则最后一个学生的id不交换。对于这个问题我们用case when 来解决。

2.首先我们用mod()找出为奇数的 id,并判断此 id 是否为最后一个,也就是用 count(*)计算出所有数据的个数,并与找出的 id 进行比较,若是最后一个则让它返回 id,不对其进行交换,若不是最后一个,则让id = id + 1。如果均不满足上述条件,那说明 id 为偶数,使 id = id -1,最后按id的升序降序排序即可。

代码实现

sql 复制代码
select (case
            when mod(id,2) = 1 and id = (select count(*)from seat) then id
            when mod(id,2) then id + 1
            else id - 1
            end) as id, student
from seat
order by id

测试结果

相关推荐
布朗克1682 小时前
MySQL UNION 操作符详细说明
数据库·mysql·union
喵桑..5 小时前
视图是什么?有什么用?什么时候用?MySQL中的视图
数据库·mysql
奋进小子6 小时前
达梦DISQL执行SQL和SQL脚本
数据库·sql
EasyCVR6 小时前
视频汇聚系统EasyCVR调用设备录像保活时视频流不连贯问题解决方案
数据库·ubuntu·音视频·云存储·云端录像
YueiL7 小时前
Linux文件系统基石:透彻理解inode及其核心作用
linux·网络·数据库
老华带你飞9 小时前
数码论坛|基于SprinBoot+vue的数码论坛系统(源码+数据库+文档)
java·前端·数据库·vue.js·论文·毕设·数码论坛系统
独泪了无痕9 小时前
Hutool-RedisDS:简化Redis操作的Java工具类
数据库·redis
北极糊的狐10 小时前
接口返回504 Gateway Time-out 错误,这意味着请求在网关或代理服务器等待上游服务器响应时超时。以下是可能的原因和排查建议:
数据库·gateway
sssnnndddfff10 小时前
Redis原理,命令,协议以及异步方式
数据库·redis·缓存
AllData公司负责人11 小时前
DataFun联合开源AllData社区和开源Gravitino社区将在8月9日相聚数据治理峰会论坛
大数据·数据库·sql·开源