day24-MySQL多表

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  码表关联(中间表关联):

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值