一、查询规则

本文介绍 MySQL 进阶查询知识。涵盖查询规则(总量、单位、方向、量组)、分组查询(group by、having)、聚合查询(count、sum、avg、max、min)以及联合查询(表关联设计、笛卡尔积拼接、内连接、左外连接、全外连接、自连接)。重点讲解了如何通过 group by 分组筛选,聚合函数计算逻辑,以及多表关联时的连接方式与数据合并策略。


计算总量 往指定列竖直延伸
计算单位 是一条行水平对应
计算方向 是水平合或竖直合,除了聚合函数的计算方向为计算单位竖直合,其它的计算方向都为水平合
计算量组 是一次计算进行的对象量,一个量组 对应一个计算结果,通过group by以指定列字段合数据相同进行分组
select col,... from tb_name where 条件 group by col,... having 条件;
group by 分组是按照 指定列字段 水平单位合数据相同的上下水平划分成组
where 条件 在分组之前 进行的条件筛选,写在 group by 的前面,having 条件 在分组之后 对合组结果 进行的条件筛选,写在 group by 的后面
sql 里,函数的参数是列
select count([distinct] col) from tb_name;
计算 每个计算量组里 计算单位的个数,除全列查询外 计算单位的数据为 null 的 不计入计算单位个数
select sum([distinct] col) from tb_name;
计算 每个计算量组里 计算单位的数据和,会对计算单位里的数据 强转成 double进行计算,遇到 null 会跳过不参与运算
select avg([distinct] col) from tb_name;
计算 每个计算量组里 计算单位的数据平均值
select max([distinct] col) from tb_name;
计算 每个计算量组里 计算单位的数据最大值
select min([distinct] col) from tb_name;
计算 每个计算量组里 计算单位的数据最小值
在表内 有信息完整的 关联字段互联的 多表 能通过关联字段拼接 把表信息 完整合并成大表 在一起

由于 mysql 不支持数组,设计增添表中的关联字段时,最好直接取一个 只有单向对应对象的表 为主对表,将主对表的记录全穷举完 为完整的一侧信息,再将关联字段 对着在主对表完整的侧面 进行共字段纽带的 对应信息填充
如果两对象是多对多的关系,主对表必须得 多向对应对象时,每个记录同时对应的 关联字段多个数据 会成数组
要将数组内容 并着重复 id 向下拆分成 一对一的多个记录
一般是不会在主对表原表上 进行修改拆分 改变原表的记录行数据,而是再设计一个 存放关联字段的中枢表 来存放这些拆分出的 所有一对一的关联记录,拼接时 两个表都往中枢表 关联字段地拼接,最后三个表拼接在一起 成完整信息的大表

多个表中 已设计好有关联字段在内 能互相拼接的多表 去笛卡尔积拼接
合并后的大表的信息是完整的 但有过载着错误合拼的记录,包含有 关联字段数据不同地合拼的 错误拼接记录 与关联字段数据相同能并的 正确拼接的记录
用两表的 两关联字段数据相同的正确连接条件 搜索出完整的 正确拼接记录 (内连接)
select col,... from tb_name1,tb_name2 where rec1 = rec2(and...);
select col,... from tb_name1 join tb_name2 on rec1 = rec2 (and...) join tb_name3 on rec1 = rec3;
内连接即搜索 左右记录能相同合并共内的 正确拼接的记录
select col,... from tb_name1 left join tb_name2 on rec1 = rec2;
把表 1 左外连接表 2,左外连接会确保 内正确连接完后 左表记录没有连接上的记录 也全搜索出来,此时它对应连接的右表记录 则为空
全外连接会确保 内正确连接完后 左右表记录没有连接上的记录 也都全搜索出来,此时它们各自对应连接的左右表记录 为空的
select col,... from tb_name as name1, tb_name as name2 where name1.recol =name2.recol
将表 自己与自己进行笛卡尔积拼接,sql 中的条件比较 都是对列与列之间进行的,如果需要 对行与行之间进行条件比较,就自己的字段 对自己笛卡尔积 复制一份 到列有,行与行内容之间进行的比较 就转到列上有了 就可用条件进行 行与行内容的比较了

微信公众号「极客日志」,在微信中扫描左侧二维码关注。展示文案:极客日志 zeeklog
在线格式化和美化您的 SQL 查询(它支持各种 SQL 方言)。 在线工具,SQL 美化和格式化在线工具,online
解析 INSERT 等受限 SQL,导出为 CSV、JSON、XML、YAML、HTML 表格(见页内语法说明)。 在线工具,SQL 转 CSV/JSON/XML在线工具,online
CSV 与 JSON/XML/HTML/TSV/SQL 等互转,单页多 Tab。 在线工具,CSV 工具包在线工具,online
将字符串编码和解码为其 Base64 格式表示形式即可。 在线工具,Base64 字符串编码/解码在线工具,online
将字符串、文件或图像转换为其 Base64 表示形式。 在线工具,Base64 文件转换器在线工具,online
将 Markdown(GFM)转为 HTML 片段,浏览器内 marked 解析;与 HTML 转 Markdown 互为补充。 在线工具,Markdown 转 HTML在线工具,online