高频 SQL 50题(基础版)| 连接


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

文章目录

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

P1068. 产品销售分析 I (外连接)

对应的SQL语句:

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


对应的SQL语句:

**思路1:**我们把没有交易的visit_id挑选出来后,分组后即可根据customer_id计数

**思路2:**两个表左连接Visits后,挑选出transaction_idnull的,分组使用聚合函数查询

P197. 上升的温度

对应的SQL语句:

日期函数 DATEDIFF🍋‍🟩

  • DATEDIFF(a.recordDate, b.recordDate) = 1:保证 a 的日期比 b 晚 1 天(前一天)

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

对应的SQL语句:

四舍五入ROUND 🍋‍🟩

**解法一:**内连接,两个相同的表进行操作

条件句IF 🍋‍🟩

**解法二:**只使用一个表,使用 IFSUMDISTINCT

P577. 员工奖金

对应的SQL语句:

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


对应的SQL语句:

交叉联表CROSS JOIN 🍋‍🟩

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


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

相关推荐
小陳参上2 小时前
用Python创建一个Discord聊天机器人
jvm·数据库·python
changhong19863 小时前
如何在 Spring Boot 中配置数据库?
数据库·spring boot·后端
执笔画情ora5 小时前
Postgresql数据库管理-pg_xact
数据库·postgresql·oracle
南棱笑笑生6 小时前
20260310在瑞芯微原厂RK3576的Android14查看系统休眠时间
服务器·网络·数据库·rockchip
JuneXcy6 小时前
第4章 Mysql数据操纵语句--单表查询
mysql
XDHCOM6 小时前
ORA-32152报错咋整啊,数据库操作遇到null number问题远程帮忙修复
服务器·数据库·oracle
专利观察员6 小时前
输配电行业创新转型实践:南宁迪**力有限公司的专利策略调整、专利检索工具采用
数据库·科技·专利·专利申请
jgyzl6 小时前
2026.3.9 Redis内存回收内存淘汰
数据库·redis·缓存
白露与泡影6 小时前
MySQL 时间类型选型避坑:timestamp 和 datetime 该怎么选?
数据库·mysql
青槿吖8 小时前
第二篇:告别XML臃肿配置!Spring注解式IOC/DI保姆级教程,从入门到真香
xml·java·开发语言·数据库·后端·sql·spring