SQL力扣

今天的题好多case then else end的

608-tree-node

https://leetcode.com/problems/tree-node/description/

树节点,流控制语句CASE,2025年6月13日 星期五

sql 复制代码
-- 
select id,
       case
           when p_id is null then 'Root'
            when Tree.id in (select p_id from Tree) then 'Inner'
            else 'Leaf'
        end as type
from Tree

错误的答案和原因

sql 复制代码
select
    id,
    case when p_id is null then "Root"
         when id not in (select p_id from tree) then "Leaf"
         else "Inner"
    end as Type
from
    tree

A not in B的原理是拿A表值与B表值做是否不等的比较, 也就是a != b. 在sql中, null是缺失未知值而不是空值(详情请见MySQL reference).

当你判断任意值a != null时, 官方说, "You cannot use arithmetic comparison operators such as =, <, or <> to test for NULL", 任何与null值的对比都将返回null. 因此返回结果为否,这点可以用代码 select if(1 = null, 'true', 'false')证实.

从上述原理可见, 当询问 id not in (select p_id from tree)时, 因为p_id有null值, 返回结果全为false, 于是跳到else的结果, 返回值为inner. 所以在答案中,leaf结果从未彰显,全被inner取代.

610-triangle-judgement

https://leetcode.com/problems/triangle-judgement/

case then else,2025年6月13日 星期五

sql 复制代码
select x, y, z,
       case
           WHEN x + y > z AND x + z > y AND y + z > x THEN 'Yes'
           else 'No'
        end as 'triangle'
from Triangle

619-biggest-single-number

https://leetcode.com/problems/biggest-single-number/description/

单一数字 是在 MyNumbers 表中只出现一次的数字。

找出最大的 单一数字 。如果不存在 单一数字 ,则返回 null 。

只出现一次的最大数字,2025年6月13日 星期五

sql 复制代码
select max(t.num) AS num
from (
         select num
         from MyNumbers
         group by num
         having count(num) = 1
     ) t

620-not-boring-movies

https://leetcode.com/problems/not-boring-movies/description/

发现自己容易把SQL和Python混淆,这里的mod,写成了%2 == 1

mod(id, 2) = 1,2025年6月13日 星期五

sql 复制代码
select id, movie, description, rating
from cinema
where mod(id, 2) = 1 and description != 'boring'
order by rating desc

626-exchange-seats

https://leetcode.com/problems/exchange-seats/description/

交换位置,2025年6月13日 星期五

sql 复制代码
-- 对于所有座位 id 是奇数的学生,修改其 id 为 id+1,如果最后一个座位 id 也是奇数,则最后一个座位 id 不修改。对于所有座位 id 是偶数的学生,修改其 id 为 id-1。
select (case when mod(id, 2) = 1 and counts != id then id + 1
            when mod(id, 2) = 1 and counts = id then id
        else id-1
        end) as id,
       student
from seat,
     (select count(*) as counts from seat) as seat_counts
order by id asc
相关推荐
瑞雨溪1 分钟前
力扣题解:740.删除并获得点数
算法·leetcode·职场和发展
液态不合群2 分钟前
Java中线程安全问题的原因和解决方案
java·数据库
鲨莎分不晴3 分钟前
给 Hadoop 插上 SQL 的翅膀:Apache Hive 架构与实战全解
hadoop·sql·apache
程序员柒叔3 分钟前
Dify 集成-数据库与缓存
数据库·缓存·dify
栗子叶4 分钟前
深入理解 MySQL 半同步复制:AFTER_SYNC 为何能避免主从同步数据丢失?
数据库·mysql·adb·高可用·主从同步
程序员-King.5 分钟前
day125—二分查找—寻找峰值(LeetCode-162)
算法·leetcode·职场和发展
老鼠只爱大米6 分钟前
LeetCode算法题详解 3:无重复字符的最长子串
算法·leetcode·面试题·滑动窗口·无重复字符的最长子串·最长子串
我科绝伦(Huanhuan Zhou)19 分钟前
MySQL主主复制管理器(MMM):技术原理与实践架构解析
数据库·mysql·架构
步步为营DotNet44 分钟前
深度解析.NET 中IAsyncEnumerable:异步迭代的高效实现与应用】
服务器·数据库·.net