联合查询

1.为什么要使用联合查询?

联合查询也叫多表查询。在设计数据库表时,由于范式的要求,数据被拆分到多个表中,在查询一条数据的完整信息,就要从多个表中获取数据。

2.多表查询时MySQl内部是怎样计算的?

笛卡尔积

多表查询是一个低效操作,如果一次联合的表过多,SQL执行的会很慢,造成系统卡顿

3.内连接

1.语法

2.查询学生的班级及班级名称

MySQL内部进行笛卡尔运算后得到的结果是混乱的,需要加上条件得到期望结果

3.查询学生姓名为孙悟空的个人信息和班级信息alter

内连接还可写为:

4.查询唐三藏同学的成绩alter

5.查询所有同学的总成绩

6.查询每个同学每门课的成绩

4.外连接

外连接与内连接得到的结果可能不同

1.外连接的结果与表内数据对应关系有关

1.当两个表一一对应时

1.内连接
2.左外连接
3.右外连接

2.当两个表数据不一一对应时

注意:补充:在MysQl安全更新模式下,要删除表内全部数据,先关闭安全模式,才能进行删除

MySQL认为

delete from stu;

delete from score;

不安全的原因是:没有where条件

1.内连接

得到两个中同时存在的结果

2.左外连接

左表的全部内容

3.右外连接

右表的全部内容

5.全外连接MySQL不支持

相关推荐
这个DBA有点耶5 小时前
DBA的AI助手:向量检索与NL2SQL入门
数据库·人工智能·postgresql·学习方法·dba
basketball6166 小时前
SQL 常用数据格式化操作方法总结
数据库·sql
TE-茶叶蛋7 小时前
数据库-引用完整性(referential integrity)
数据库
IronMurphy7 小时前
MySQL拷打第二讲
数据库·mysql
裴东青9 小时前
ProxySQL实现MySQL主从集群的读写分离
数据库·mysql·adb
handler019 小时前
【MySQL】教你库与表的增删查改操作(基础)
运维·数据库·笔记·sql·mysql·数据·分析
染指111010 小时前
9.LangChain框架(实现RAG)
数据库·人工智能·算法·机器学习·ai·大模型
2401_8734794010 小时前
主流IP离线库(IP数据云、纯真、IPIP.NET)怎么选?全面对比分析
服务器·网络·数据库
毋语天10 小时前
Redis 零基础实战指南:从核心原理到生产落地的完整路线
数据库·redis·缓存
weixin_4083180411 小时前
教育行业直播系统搭建指南
java·大数据·数据库