高频 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查询即可


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

相关推荐
Adorable老犀牛14 小时前
MySQL Server Exporter:Prometheus 监控 MySQL/MariaDB 指南
mysql·prometheus·mariadb
凡人叶枫14 小时前
Effective C++ 条款08:别让异常逃离析构函数
java·linux·数据库·c++·嵌入式开发
herinspace14 小时前
管家婆财工贸软件中关于价格常见问题小结
服务器·网络·数据库·电脑·管家婆软件
北风toto15 小时前
本体和智能体协同核心5步骤(生成sql语句)
数据库·sql
IvorySQL15 小时前
PostgreSQL 技术日报 (6月10日)|多工具版本更新,PG19 图语法落地
数据库·postgresql
lsyeei15 小时前
数据库分库分表
数据库
这个DBA有点耶15 小时前
Vibe Coding 是什么?当“感觉编程”遇上数据库
数据库·人工智能·架构·学习方法·ai编程·程序员创富·改行学it
范什么特西15 小时前
重点:mybatis注意细节
java·mysql·mybatis
数智化精益手记局15 小时前
拆解项目管理平台核心功能:看项目管理平台如何解决跨部门协作难题与多项目并行场景
大数据·运维·数据库·人工智能·产品运营
德迅云安全-小潘16 小时前
网站遭遇SQL注入攻击?应急处置、漏洞修复与长效防御完整方案
网络·sql·oracle