数据库表查询的内连接、外连接、交叉连接实现方式
来源:互联网 发布:qq电脑加速软件 编辑:程序博客网 时间:2024/06/05 06:16
连接查询方式有:
内连接、外连接(左连接、右连接、全连接)、交叉连接
左连接和右连接的区别:
左连接以左表为基准进行查询,左表数据会全部显示出来,右表如果和左表匹配的数据则显示相应字段的数据,如果不匹配,则显示为NULL;右连接刚好相反。
全连接就是先以左表进行左外连接,然后以右表进行右外连接。
说明:所谓的基准,就是以某张表的限制条件查询条件为准!
具体如下:
一、内连接
内连接查询操作列出与连接条件匹配的数据行,它使用比较运算符比较被连接列的列值。内连接分三种:
1、等值连接:在连接条件中使用等于号(=)运算符比较被连接列的列值,其查询结果中列出被连接表中的所有列,包括其中的重复列。
2、不等连接:在连接条件使用除等于运算符以外的其它比较运算符比较被连接的列的列值。这些运算符包括>、>=、<=、<、!>、!<、!=和<>。
3、自然连接:在连接条件中使用等于(=)运算符比较被连接列的列值,但它使用选择列表指出查询结果集合中所包括的列,并删除连接表中的重复列。
二、外连接
返回到查询结果集合中的不仅包含符合连接条件的行,而且还包括左表(左外连接时)、右表(右外连接时)或两个边接表(全外连接)中的所有数据行。
三、交叉连接
交叉连接不带WHERE 子句,它返回被连接的两个表所有数据行的笛卡尔积,返回到结果集合中的数据行数等于第一个表中符合查询条件的数据行数乘以第二个表中符合查询条件的数据行数。例,titles表中有6类图书,而publishers表中有8家出版社,则下列交叉连接检索到的记录数将等于6*8=48行。
第二部分、实例说明
- 实例
Book表:
一、内连接
select *
from [Book] as b,[Student] as s
where b.StudentId=s.StudentId
等价于如下(也可以不要关键字inner,此为系统默认),但这种方法不能再用left join等外连接了
select *
from [Book] as b inner join [Student] as s
ON b.StudentId=s.StudentId
这种方法还可以加and条件,并且后面可能接着用left join等外连接
相当于内连接的向右连接。以from
说明
这与where b.StudentId=s.StudentId或者s.StudentId=b.StudentId位置没有关系。它仅仅代表满足条件而已,不判定谁为基准。以下外连接,交叉连接相同操作。
二、外连接
1、左外连接
代码
select *
from [Book] as b left join [Student] as s
ON b.StudentId=s.StudentId
结果
执行过程
即以from [Book] left join [Student]的Book表为基准,即以Book表(b表)的b.StudentId为基准。遍历Student表(s表)中与之匹配的b.StudentId。若b.StudentId含有s.StudentId匹配项,则进行拼接,然后遍历Student表的下一条s.StudentId,当查询完毕则进入下一条b.StudentId。若b.StudentId没有相应s.StudentId匹配项时,则显示左表的项,拼接右表的项显示为NULL。
2、右外连接
代码
select *
from [Book] as b right join [Student] as s
ON b.StudentId=s.StudentId
结果
执行过程
即以from [Book] right join [Student]的Student表为基准,即以Student表(s表)的s.StudentId为基准。遍历Book表(b表)中与之匹配的s.StudentId。若s.StudentId含有b.StudentId匹配项,则进行拼接,然后遍历Book表的下一条b.StudentId,当查询完毕则进入下一条s.StudentId。若s.StudentId没有相应b.StudentId匹配项时,则显示右表的项,拼接左表的项显示为NULL。
3、全外连接
代码
select *
from [Book] as b full outer join [Student] as s
ON b.StudentId=s.StudentId
结果
执行过程
即以from [Book] full outer join [Student]中先以Book表进行左外连接,然后以Student表进行右外连接。
三、交叉连接
代码
select *
from [Book] as b CROSS Join [Student] as a
Order by b.BookId
结果
连接查询方式有:
内连接、外连接(左连接、右连接、全连接)、交叉连接
左连接和右连接的区别:
左连接以左表为基准进行查询,左表数据会全部显示出来,右表如果和左表匹配的数据则显示相应字段的数据,如果不匹配,则显示为NULL;右连接刚好相反。
全连接就是先以左表进行左外连接,然后以右表进行右外连接。
说明:所谓的基准,就是以某张表的限制条件查询条件为准!
具体如下:
一、内连接
内连接查询操作列出与连接条件匹配的数据行,它使用比较运算符比较被连接列的列值。内连接分三种:
1、等值连接:在连接条件中使用等于号(=)运算符比较被连接列的列值,其查询结果中列出被连接表中的所有列,包括其中的重复列。
2、不等连接:在连接条件使用除等于运算符以外的其它比较运算符比较被连接的列的列值。这些运算符包括>、>=、<=、<、!>、!<、!=和<>。
3、自然连接:在连接条件中使用等于(=)运算符比较被连接列的列值,但它使用选择列表指出查询结果集合中所包括的列,并删除连接表中的重复列。
二、外连接
返回到查询结果集合中的不仅包含符合连接条件的行,而且还包括左表(左外连接时)、右表(右外连接时)或两个边接表(全外连接)中的所有数据行。
三、交叉连接
交叉连接不带WHERE 子句,它返回被连接的两个表所有数据行的笛卡尔积,返回到结果集合中的数据行数等于第一个表中符合查询条件的数据行数乘以第二个表中符合查询条件的数据行数。例,titles表中有6类图书,而publishers表中有8家出版社,则下列交叉连接检索到的记录数将等于6*8=48行。
第二部分、实例说明
实例
Book表:
数据库表与表连接的方式(内连接、外连接[左连接、右连接、全连接]、交叉连接)
Student表:
数据库表与表连接的方式(内连接、外连接[左连接、右连接、全连接]、交叉连接)
一、内连接
select *
from [Book] as b,[Student] as s
where b.StudentId=s.StudentId
等价于如下(也可以不要关键字inner,此为系统默认),但这种方法不能再用left join等外连接了
select *
from [Book] as b inner join [Student] as s
ON b.StudentId=s.StudentId
这种方法还可以加and条件,并且后面可能接着用left join等外连接
结果为:
数据库表与表连接的方式(内连接、外连接[左连接、右连接、全连接]、交叉连接)
执行过程
相当于内连接的向右连接。以from [Book] inner join [Student]等式右边为基准,即以Student表(等式右表,s表)的s.StudentId为基准,遍历Book表(等式左表,Book表)中与之匹配的b.StudentId,然后拼接返回。结果含有重复的列,b.StudentId和s.StudentId。
说明
这与where b.StudentId=s.StudentId或者s.StudentId=b.StudentId位置没有关系。它仅仅代表满足条件而已,不判定谁为基准。以下外连接,交叉连接相同操作。
二、外连接
1、左外连接
代码
select *
from [Book] as b left join [Student] as s
ON b.StudentId=s.StudentId
结果
数据库表与表连接的方式(内连接、外连接[左连接、右连接、全连接]、交叉连接)
执行过程
即以from [Book] left join [Student]的Book表为基准,即以Book表(b表)的b.StudentId为基准。遍历Student表(s表)中与之匹配的b.StudentId。若b.StudentId含有s.StudentId匹配项,则进行拼接,然后遍历Student表的下一条s.StudentId,当查询完毕则进入下一条b.StudentId。若b.StudentId没有相应s.StudentId匹配项时,则显示左表的项,拼接右表的项显示为NULL。
2、右外连接
代码
select *
from [Book] as b right join [Student] as s
ON b.StudentId=s.StudentId
结果
数据库表与表连接的方式(内连接、外连接[左连接、右连接、全连接]、交叉连接)
执行过程
即以from [Book] right join [Student]的Student表为基准,即以Student表(s表)的s.StudentId为基准。遍历Book表(b表)中与之匹配的s.StudentId。若s.StudentId含有b.StudentId匹配项,则进行拼接,然后遍历Book表的下一条b.StudentId,当查询完毕则进入下一条s.StudentId。若s.StudentId没有相应b.StudentId匹配项时,则显示右表的项,拼接左表的项显示为NULL。
3、全外连接
代码
select *
from [Book] as b full outer join [Student] as s
ON b.StudentId=s.StudentId
结果
数据库表与表连接的方式(内连接、外连接[左连接、右连接、全连接]、交叉连接)
执行过程
即以from [Book] full outer join [Student]中先以Book表进行左外连接,然后以Student表进行右外连接。
三、交叉连接
代码
select *
from [Book] as b CROSS Join [Student] as a
Order by b.BookId
结果
数据库表与表连接的方式(内连接、外连接[左连接、右连接、全连接]、交叉连接)
执行过程
即是按照Order排序的Id,把要Join的右表无条件拼接过来。这样依次执行,这样这种记录便为两个表的记录的笛卡尔积。
执行过程
即是按照Order排序的Id,把要Join的右表无条件拼接过来。这样依次执行,这样这种记录便为两个表的记录的笛卡尔积。
- 数据库表查询的内连接、外连接、交叉连接实现方式
- 数据库表与表连接的方式(内连接、外连接[左连接、右连接、全连接]、交叉连接)
- 内连接,外连接,交叉连接--数据库查询语句学习
- 多表查询的分类,连接查询,内连接,外连接,交叉连接,子查询
- 数据库 内连接 外连接 交叉连接 的区别
- 数据库中查询的各种连接(左连接,右连接,全连接,内连接,交叉连接,自连接)
- 数据库中查询的各种连接(左连接,右连接,全连接,内连接,交叉连接,自连接)
- 4.mysql数据库创建,表创建模等模板脚本,mysql_SQL99标准的连接查询(内连接,外连接,满外连接,交叉连接)
- 数据库 内连接 外连接 交叉连接 自连接
- MySQL的多表查询(交叉连接,内连接,外连接)
- 表间的内连接、外连接、交叉连接
- 多表连接查询(内,外,交叉连接)
- 多表连接查询(内,外,交叉连接)
- 数据库多表连接查询(外连接和内连接)
- 数据库多表连接查询(外连接和内连接)
- SQL 连接的方式(内连接,外连接,交叉连接)
- SQL连接查询 内连接,左外连接,右外连接,全连接,交叉连接
- T-SQL 表连接(内连接,外连接,交叉连接)
- spring boot入门学习
- JS二级联动选择框动态创建和编辑实现
- unity 判断物品是否出现在角色面前
- 安卓双向滑动的实现方法
- Sublime Text3 配置TypeScript,使其高亮,提示
- 数据库表查询的内连接、外连接、交叉连接实现方式
- read: unexpected EOF
- 行为型模式总结篇(1)
- iOS之《Effective Objective-C 2.0》读书笔记(50)
- JOSN语法以及和XML的比较
- 第四周项目三(1)—链表的逆置
- 浪曦_Struts2应用开发系列_第2讲.Struts2的类型转换--出现的问题笔记
- 设计模式阅读备忘笔记-策略模式
- Spring事物管理