SQL查询技巧全 Strategy Guide

连接查询的步骤

1.确认要查询数据的表

2.取笛卡尔积

3.确认表与表之间的连接条件

4.确认查询的字段条件

5.精删查询字段

聚合查询

聚合查询是 一种对数据库 行与行之间 的 操作

聚合函数

COUNT

统计行数或非空值数量

-- 统计表中所有行数
SELECT COUNT(*) FROM employees;

-- 统计特定列非NULL值的数量
SELECT COUNT(department) FROM employees;

SUM

计算数值列的总和

-- 计算工资总和
SELECT SUM(salary) FROM employees;

-- 带条件的求和
SELECT SUM(salary) FROM employees WHERE department = 'Sales';

AVG

计算数值列的平均值

-- 计算平均工资
SELECT AVG(salary) FROM employees;

-- 保留两位小数
SELECT ROUND(AVG(salary), 2) FROM employees;

MAX/MIN

获取列中的最大/最小值

-- 获取最高工资
SELECT MAX(salary) FROM employees;

-- 获取最低工资
SELECT MIN(salary) FROM employees WHERE hire_date > '2020-01-01';

分组查询

GROUP BY

指定分组字段

HAVING子句

对聚合结果进行过滤(类似 WHERE但用于聚合后)。

查询公司内收入大于5000的员工

SELECT department, AVG(salary) AS avg_salary
FROM employees
GROUP BY department
HAVING AVG(salary) > 5000;

合并查询

SELECT column1, column2 FROM table1
UNION [ALL]
SELECT column1, column2 FROM table2;

  • UNION :自动去重。
  • UNION ALL :保留所有行,包括重复项,性能更高

连接查询

内连接(INNER JOIN)

SELECT A.column1, B.column2
FROM tableA A(别名)
(INNER) JOIN tableB B(别名)ON A.key = B.key;

多表连接

SELECT A.column1 , B.column2, C.column3 (x.xx 选中表中对应的数据 ,避免数据的二重性)
FROM tableA A
JOIN tableB B ON A.key1 = B.key1
JOIN tableC C ON B.key2 = C.key2;

外连接(FULL JOIN)

左连接(LEFT JOIN) & 右连接(RIGHT JOIN)

如果是联合查询时

完全显示左表那就是左连接(

左连接 返回左表中的所有记录,无论右表中是否有匹配的记录。

如果 右表 中没有匹配的记录,结果中右表 的字段将显示为NULL

SELECT columns
FROM table1
LEFT JOIN table2 ON table1.column = table2.column;

完全显示右表那就是右连接(右侧同理)

SELECT columns
FROM table1
RIGHT JOIN table2 ON table1.column = table2.column;

自连接(SELF JOIN)

SELECT a.column1, b.column2
FROM 表名 as a, 表名 as b
WHERE a.字段 = b.字段;

SELECT a.column1, b.column2
FROM 表名 as a
JOIN 表名 as b ON a.字段 = b.字段;

子查询(嵌套查询)

-- 子查询方式
SELECT nameFROM employees WHERE department_id IN (SELECT id FROM departments WHERE location = 'NY');

-- JOIN方式
SELECT e.name FROM employees e JOIN departments d ON e.department_id = d.id WHERE d.location = 'NY';

相关子查询:子查询依赖主查询的每一行数据

WHERE EXISTS (SELECT 1 FROM departments WHERE departments.id = employees.department_id))。

非相关子查询:子查询独立执行,不依赖主查询

WHERE salary > (SELECT AVG(salary) FROM employees))。

EXISTS/NOT EXISTS子查询

复制代码
SELECT name FROM departments d 
WHERE EXISTS (SELECT 1 FROM employees e WHERE e.department_id = d.id);

EXISTS 后的查询语句

如果存在返回结果 则就执行外层查询,如果返回为一个空结果集 则不执行查询

(相当于if条件语句 有结果存在返回 true 没有则返回结果false)

一条SQL语句各部分的执行顺序

select distinct id ,name,avg(age)from student join class on student,class_id = class.id where class.id = 1 group by student.id having avg(age) > 0order by student.id asc limit 100;

(不考虑能执行成功)

from -- > join on -- > where -- > group by -- > having -- > select -- > distinct -- > order by -- > limit

相关推荐
_ku_ku_16 分钟前
数据库系统原理 · 事务管理与恢复 · 自学总结
数据库·oracle
lifewange2 小时前
Redis 集合(Set)运算完全指南
数据库·chrome·redis
TDengine (老段)2 小时前
TDengine RAFT共识协议 — 选举、日志复制、快照与仲裁
android·大数据·数据库·物联网·架构·时序数据库·tdengine
Full Stack Developme3 小时前
Spring Boot 事务管理完整教程
java·数据库·spring boot
m0_702036534 小时前
mysql如何通过索引减少行锁范围_mysql索引与加锁逻辑
jvm·数据库·python
qxwlcsdn5 小时前
如何用 IndexedDB 存储从 API 获取的超大列表并实现二级索引
jvm·数据库·python
phltxy5 小时前
Redis 主从复制
java·数据库·redis
2301_809244535 小时前
C#怎么使用协变和逆变 C#泛型中的in和out关键字协变逆变是什么意思怎么用【语法】
jvm·数据库·python
知识汲取者5 小时前
巨量引擎营销 API 完整文档
开发语言·数据库·python
Aurorar0rua5 小时前
CS50 x 2024 Notes C -12
c语言·开发语言·学习方法