0目录
第三章 MySQL多表
1.MySQL多表 2.主外键 |
1.MySQL多表
1.1 分组查询定义: 根据给定数据列的每个成员对查询结果进行分组统计,最终得到一个分组汇总表 |
1.2 分组查询语法: select…… from <表名> where…… group by ……; |
1.3 分组查询解析: 分组与排序结合(排序必须写在分组的后面) |
1.4 分组实战1:分别统计每个年级男、女生人数 |
1.5 分组筛选定义 定义:分组之后的筛选(过滤) GROUP BY子句 HAVING子句; -- 用来从分组的结果中筛选行 |
1.6 分组筛选语法 SELECT …… FROM <表名> GROUP BY …… HAVING…… |
1.7 分组实战1 |
1.8 多表关联查询种类 内连接 (INNER JOIN) 左外连接 (LEFT JOIN) 右外连接 (RIGHT JOIN) 自连接 (SELF JOIN) |
1.9 内连接: 使用比较运算符 根据每个表的通用列中的值匹配两个表中相同内容的行 ,拼接在一起生成新的表 |
1.10 左外连接(左连接) 根据左表的记录,在被连接的右表中找出符合条件的记录与之匹配,如果找不到与左表匹配的,用null表示(左表为主,根据左表中的studentNo匹配,B表匹配到的对应显示,未匹配到的值显示为null) |
1.11 右外连接: 右外连接的原理与左外连接相同,右表逐条去匹配记录;否则NULL填充 拓展:左外=右外的情况 |
1.12 自连接: 把category表看做两张一模一样的表,然后将这两张表连接查询(自连接) |
2.主外键
2.1 物理主外键 问题1:删除数据较为麻烦(必须遵循删除顺序:user-->role-->permission) 问题2:添加数据较为麻烦(必须遵循添加顺序:permission-->role-->uesr) |
2.2 逻辑主外键:删除物理主外键,达到业务上的主外键即可 |
2.3 码表关联(中间表关联): |