文章目录
表的内连和外连
表的连接分为内连和外连
内连接
利用where
子句对两种表形成的笛卡儿积进行筛选
语法:
sql
select 字段 from 表1 inner join 表2 on 连接条件 and 其他条件;
- 显示SMITH的名字和部门名称
员工表和部门表
用前面学习到的用两表的笛卡尔积,以及两者的deptnp
做筛选得到有效信息,再使用条件SMITH
即可的出答案,如下,
用标准的内连接SQL
- 员工表和部门号放在from子句中并通过inner join关键字隔开
- on子句后指明内连接的条件为员工的部门号等于部门的部门号,筛选得到有效信息
- 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这种情况
列出部门名称和这些部门的员工信息,同时列出没有员工的部门
列出部门名和员工信息,一张表肯定不够,需要dept
和emp
两张
连接条件就是部门的部门号要等于员工所在的部门号
使用内连接进行查询,将会显示出所有满足连接条件的记录
但是并没有满足同时列出没有员工的部门
也就是说,部门表当中的内容需要完全被显示出来
方案一:
部门表放在左侧,使用左外连接
方案二:
部门表放在右侧,使用右外连接