【LeetCode】【SQL】刷题笔记

code格式规范:
所有关键字大写,关键字右边对齐,子句缩进
列名最好和表中的列名一样(大小写一样)

SELECT  name
FROM  customer C
WHERE C.id NOT IN ( SELECT C1.id 
                    FROM customer C1
                    WHERE C1.referee_id = 2 );

参考资料:

官方文档:【参考:MySQL :: MySQL 5.7 参考手册 :: 13 SQL 语句

【参考:MySQL 中文文档 | MySQL 中文网

【参考:SQL中的谓词 - 知乎

题目以类型归类,记录常用且易错的类型

SQL基础

百度:SQL执行顺序

【参考:sql语句的执行顺序以及流程_sql执行顺序_۩ﺴ往后余生ﺴ۩的博客-CSDN博客

在这里插入图片描述


IS NULL

【参考:584. 寻找用户推荐人 【比官方细,千字干货!】(三值运算,NULL) - 寻找用户推荐人 - 力扣(LeetCode)

【参考:584. 寻找用户推荐人 - 简单 - 力扣(LeetCode)

SELECT name FROM customer WHERE referee_id != 2 OR referee_id IS NULL;

多表查询

【参考:183. 从不订购的客户 - 力扣(LeetCode)

  • 子查询
select customers.name as 'Customers' # as 别名
from customers
where customers.id not in
(
    select customerid from orders
);
# 先从orders中找出customerid

在这里插入图片描述

SELECT c.Name as Customers
FROM Customers as c
left join Orders as o on c.Id=o.CustomerId
where o.Id IS NULL

IF 表达式

IF( expr1 , expr2 , expr3 )

【参考:1873. 计算特殊奖金 - 力扣(LeetCode)
【参考:MySQL, 7种解法 - 计算特殊奖金 - 力扣(LeetCode)

SELECT 
    employee_id,
    IF( 
        employee_id%2=1 and name not like 'M%',
        salary,
        0
    ) as bonus 
FROM Employees
ORDER by employee_id 

【参考:627. 变更性别 - 力扣(LeetCode)

UPDATE Salary set sex=IF(sex='f','m','f')

CASE WHEN END

【参考:627. 变更性别 - 力扣(LeetCode)

UPDATE salary
SET
    sex = CASE sex
        WHEN 'm' THEN 'f'
        ELSE 'm'
    END

自连接

【参考:196. 删除重复的电子邮箱 - 力扣(LeetCode)

【参考:对「官方」题解中 “delete” 和 “>” 的解释,推荐! - 删除重复的电子邮箱 - 力扣(LeetCode)
2、p1.Id > p2.Id
继续之前,先简单看一下表的连接过程,这个搞懂了,理解WHERE条件就简单了👇
a. 从驱动表(左表)取出N条记录;
b. 拿着这N条记录,依次到被驱动表(右表)查找满足WHERE条件的记录;

DELETE p1 
FROM Person p1,
     Person p2
WHERE
    p1.Email = p2.Email AND p1.Id > p2.Id

正则

【参考:1527. 患某种疾病的患者 - 力扣(LeetCode)

^DIAB1表示以DIAB1开头 
|表示或者 
.表示一定有任意一个字符 
*表示重复0到无穷多个的前一个字符 
第一个\表示转义字符 
\s是指空白,包括空格、换行、Tab 缩进等所有的空白 
所以.*\sDIAB1表示DIAB1前是空格且空格前有0到无穷多个的任意字符
# Write your MySQL query statement below
select patient_id,
       patient_name,
       conditions
from Patients
where conditions rlike '^DIAB1|.*\\sDIAB1'

函数

upper lower

【参考:1667. 修复表中的名字 - 力扣(LeetCode)
【参考:【JMao】简单函数解法+分享刷题经验 - 修复表中的名字 - 力扣(LeetCode)

【参考:12.3. 字符串函数_MySQL 中文文档

# Write your MySQL query statement below
SELECT user_id,
       CONCAT(Upper(Left(name,1)),Lower(substring(name,2))) as name 
from Users 
order by user_id

concat

【参考:1484. 按日期分组销售产品 - 力扣(LeetCode)
【参考:mysql 分组拼接函数 group_concat - 按日期分组销售产品 - 力扣(LeetCode)

SELECT sell_date,
       count(distinct product) as 'num_sold',
       # 组内拼接
       group_concat(distinct product    # 去重
                    order by product asc # 分组,按照字典序升序
                    separator ',') # 间隔
                    as 'products'
from Activities
group by sell_date
order by sell_date

union all

union和union all都可以起到关联结果集的作用,区别在于:

  • union会自动去除关联的两个结果集中的重复数据,
  • union all则不会主动去除两个结果集中的重复数据,会展示所有的数据;

列转行

【参考:1795. 每个产品在不同商店的价格 - 力扣(LeetCode)

【参考:表格-列转行 - 每个产品在不同商店的价格 - 力扣(LeetCode)

# Write your MySQL query statement below
select product_id, 'store1' as store, store1 as price
from Products where store1 is not null
union all
select product_id, 'store2' as store, store2 as price
from Products where store2 is not null
union all
select product_id, 'store3' as store, store3 as price
from Products where store3 is not null;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1. 二分法 5 1.1. 什么是二分查找 5 1.2. 如何识别二分法 5 1.3. 二分法模板 6 1.3.1. 模板一 6 1.3.1.1. 模板代码 6 1.3.1.2. 关键属性 7 1.3.1.3. 语法说明 7 1.3.1.4. Lc69:x的平方根 8 1.3.1.5. Lc374:猜数大小 9 1.3.1.6. Lc33:搜索旋转数组 11 1.3.2. 模板二 13 1.3.2.1. 模板代码 13 1.3.2.2. 关键属性 14 1.3.2.3. 语法说明 14 1.3.2.4. Lc278:第一个错误版本 14 1.3.2.5. Lc162:寻找峰值 16 1.3.2.6. Lc153:寻找旋转排序数组最小值 19 1.3.2.7. Lc154:寻找旋转排序数组最小值II 20 1.3.3. 模板三 22 1.3.3.1. 模板代码 22 1.3.3.2. 关键属性 23 1.3.3.3. 语法说明 23 1.3.3.4. LC-34:在排序数组中查找元素的第一个和最后一个 23 1.3.3.5. LC-658:找到K个最接近的元素 25 1.3.4. 小结 28 1.4. LeetCode中二分查找题目 29 2. 双指针 30 2.1. 快慢指针 31 2.1.1. 什么是快慢指针 31 2.1.2. 快慢指针模板 31 2.1.3. 快慢指针相关题目 32 2.1.3.1. LC-141:链表是否有环 32 2.1.3.2. LC-142:环形链表入口 34 2.1.3.3. LC-876:链表的中间节点 37 2.1.3.4. LC-287:寻找重复数 40 2.2. 滑动窗口 43 2.2.1. 什么是滑动窗口 43 2.1.4. 常见题型 44 2.1.5. 注意事项 45 2.1.6. 滑动窗口模板 45 2.1.7. 滑动窗口相关题目 46 2.1.7.1. LC-3:无重复字符的最长子串 47 2.1.7.2. LC-76:最小覆盖子串 49 2.1.7.3. LC-209:长度最小的子数组 54 2.1.7.4. LC-239:滑动窗口最大值 57 2.1.7.5. LC-395:至少有K个重复字符的最长子串 60 2.1.7.6. LC-567:字符串排列 62 2.1.7.7. LC-904:水果成篮 64 2.1.7.8. LC-424:替换后的最长重复字符 66 2.1.7.9. LC-713:乘积小于K的子数组 67 2.1.7.10. LC-992:K个不同整数的子数组 70 2.3. 左右指针 73 2.3.1. 模板 73 2.3.2. 相关题目 73 2.3.2.1. LC-76:删除倒数第N个节点 74 2.3.2.2. LC-61:旋转链表 76 2.3.2.3. LC-80:删除有序数组中的重复项 79 2.3.2.4. LC-86:分割链表 80 2.3.2.5. LC-438:找到字符串中所有字母的异位词 82 3. 模板 85 2.3.2.6. LC-76:删除倒数第N个节点 85

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值