
🌈 个人主页: Hygge_Code
🔥 热门专栏:从0开始学习Java | Linux学习| 计算机网络
💫 个人格言: "既然选择了远方,便不顾风雨兼程"

文章目录
- [P1068. 产品销售分析 I (外连接)](#P1068. 产品销售分析 I (外连接))
- [P1581. 进店却未进行过交易的顾客](#P1581. 进店却未进行过交易的顾客)
- [P197. 上升的温度](#P197. 上升的温度)
-
- [日期函数 `DATEDIFF`🍋🟩](#日期函数
DATEDIFF🍋🟩)
- [日期函数 `DATEDIFF`🍋🟩](#日期函数
- [P1661. 每台机器的进程平均运行时间](#P1661. 每台机器的进程平均运行时间)
-
- [四舍五入`ROUND` 🍋🟩](#四舍五入
ROUND🍋🟩) - [条件句`IF` 🍋🟩](#条件句
IF🍋🟩)
- [四舍五入`ROUND` 🍋🟩](#四舍五入
- [P577. 员工奖金](#P577. 员工奖金)
- [P1280. 学生们参加各科测试的次数 🐦🔥](#P1280. 学生们参加各科测试的次数 🐦🔥)
-
- [交叉联表`CROSS JOIN` 🍋🟩](#交叉联表
CROSS JOIN🍋🟩)
- [交叉联表`CROSS JOIN` 🍋🟩](#交叉联表
P1068. 产品销售分析 I (外连接)

对应的SQL语句:

P1581. 进店却未进行过交易的顾客


对应的SQL语句:
**思路1:**我们把没有交易的
visit_id挑选出来后,分组后即可根据customer_id计数
**思路2:**两个表左连接Visits后,挑选出transaction_id为null的,分组使用聚合函数查询
P197. 上升的温度

对应的SQL语句:
日期函数 DATEDIFF🍋🟩
DATEDIFF(a.recordDate, b.recordDate) = 1:保证 a 的日期比 b 晚 1 天(前一天)

P1661. 每台机器的进程平均运行时间


对应的SQL语句:
四舍五入ROUND 🍋🟩
**解法一:**内连接,两个相同的表进行操作
条件句IF 🍋🟩
**解法二:**只使用一个表,使用
IF、SUM和DISTINCT
P577. 员工奖金

对应的SQL语句:

P1280. 学生们参加各科测试的次数 🐦🔥


对应的SQL语句:
交叉联表CROSS JOIN 🍋🟩
**思路:**本道SQL题目,若只是让我们统计每个学生的考试科目次数(不包括0次的),那么就非常简单,只需要让学生表和考试表形成左连接再使用
COUNT查询即可。 但是,这道我们需要统计所有学生所有科目的考试次数,所以我们就需要一个交叉链表(形成笛卡尔积),形成所有学生对应所有科目的表,即学生表和科目表交叉连接,再左外连接考试表,COUNT (NULL)=0正好符合 "无考试则次数为 0" 的需求,使用COUNT查询即可

如果我的内容对你有帮助,请 点赞 , 评论 , 收藏 。创作不易,大家的支持就是我坚持下去的动力!




