MySQL 表的内连和外连

文章目录

表的内连和外连

表的连接分为内连和外连

内连接

利用where子句对两种表形成的笛卡儿积进行筛选

语法:

sql 复制代码
select 字段 from 表1 inner join 表2 on 连接条件 and 其他条件;
  • 显示SMITH的名字和部门名称

员工表和部门表

用前面学习到的用两表的笛卡尔积,以及两者的deptnp做筛选得到有效信息,再使用条件SMITH即可的出答案,如下,

用标准的内连接SQL

  1. 员工表和部门号放在from子句中并通过inner join关键字隔开
  2. on子句后指明内连接的条件为员工的部门号等于部门的部门号,筛选得到有效信息
  3. and后条件为员工的姓名为SMITH

外连接

分为左外连接和右外连接

左外连接

左侧的表完全显示

语法:

sql 复制代码
select 字段名 from 表名1 left join 表名2 on 连接条件
  • 查询所有学生的成绩,如果这个学生没有成绩,也要将学生的个人信息显示出来

左边的表3和4都没有对应的成绩,但因为左外连接显示了他们的成绩,即使为NULL

而右边的表11却没有在连接后显示,因为他在左边的表没有内容;

右外连接

右边的表完全显示

语法:

sql 复制代码
select 字段名 from 表名1 right join 表名2 on 连接条件

还是上面那个问题

右边的表11都没有对应的成绩,但因为右外连接显示了他们的内容,即使为NULL

而左边的表3和4却没有在连接后显示,因为他在右边的表没有内容;

笛尔卡积也就是直接连接只会显示两个表共同有的内容,不回出现NULL这种情况

列出部门名称和这些部门的员工信息,同时列出没有员工的部门

列出部门名和员工信息,一张表肯定不够,需要deptemp两张

连接条件就是部门的部门号要等于员工所在的部门号

使用内连接进行查询,将会显示出所有满足连接条件的记录

但是并没有满足同时列出没有员工的部门

也就是说,部门表当中的内容需要完全被显示出来

方案一:

部门表放在左侧,使用左外连接

方案二:

部门表放在右侧,使用右外连接

相关推荐
倔强的石头_4 小时前
《Kingbase护城河》——猎捕慢查询:执行计划的微观解析与索引调优实战
数据库
SelectDB6 小时前
Apache Doris Python UDF:让 SQL 直接调用 Python 生态,支撑 Agent 时代复杂业务逻辑
大数据·数据库·python
jiayou641 天前
KingbaseES 表级与列级加密完全指南
数据库·后端
GBASE2 天前
G术时刻 |GBase 8s数据库事务并发控制之封锁技术介绍(下)
数据库
xiezhr3 天前
逛GitHub发现了一款免费的带AI功能的数据库管理工具
数据库·ai编程·dba
唐青枫4 天前
MySQL JSON 实战详解:从存储、查询、更新到 JSON_TABLE 与索引
sql·mysql
吃糖的小孩4 天前
给 QQ AI 机器人设计“可控记忆”:会话摘要、手动长期记忆与角色卡边界
数据库
小满8784 天前
5.Mysql事务隔离级别与锁机制
mysql
笃行3504 天前
金仓数据库数据安全双防线:静态存储加密与传输加密实战
数据库
笃行3504 天前
金仓数据库物理备份实战:sys_rman 全流程演练与误覆盖抢救
数据库