文章目录
表与表的关系
一对一关系
一对多关系
多对多关系
表与表之间的连接
笛卡尔积
什么是笛卡尔积:
内连接:
1、通过where关键字进行关联
2、通过inner join on进行关联
外连接:
1.左连接(left join)
2.右连接right join
子查询
有时候我们所需要的数据不止在一张表中,需要多个表做结合的查询,这时就需要进行表连接。
多表连接主要需要决定关系:方向性、主附关系
在一对一关系中,A表中的一行最多只能匹配B表中的一行,反之亦然,创建的就是一对一关系。
一对多关系是最常见的一种关系,A表中的一行可以匹配B表中的多行,但是B表中的一行只能匹配A表中的一行。
例如:存在部门表和人员表之间具有一对多的关系,每个部门有很多的员工,但是每个员工只属于一个部门
只有当一个相关列是一个主键或者具有唯一性约束时,才能创建一对多的关系。
在多对多的关系中,A表中一行可以匹配B表中的多行,反之亦然。
要创建这种关系,需要定义第三张表,称之为结合表,他的主键由A表和B表外部键组成
什么是笛卡尔积:
数学上,有两个集合A={a,b},B={1,2,3},则两个集合的笛卡尔积={{a,1}, {a,2}, {a,3}, {b,1}, {b,2}, {b,3}} 列出所有情况,一共是2*3=6条记录;
在数据库中,笛卡尔积是多表查询没有连接条件时返回的表结果。
笛卡尔积的元素是元组,关系A和关系B的笛卡尔积可以记为(AXB),如果A表a条,B表为b条,那么A和B的笛卡尔积为(a+b)列数,有(a*b)行的元素集合。检索出来的条目是将第一个表中的行数乘以第二个表中的行数。
避免全笛卡尔积 :在 where 加入有效的连接条件;
消除笛卡尔积:使用等值连接和非等值连接;
内连接称之为普通连接或自然连接,按照连接条件,返回两张表中的满足条件的记录。
内连接查询的特征:只关联表与表中能够匹配到的数据信息,才能有对应的查询结果,如图所示:
内连接提供了两种表与表之间的连接方式:
1、通过where关键字进行关联
注意:
- 表与表之间建立起关联的列,列名可以不一样,但是这两个列的数据类型和内容必须保持一致
- 要查询的字段,必须要在字段的前面加上表名或者表的别名
2、通过inner join on进行关联
inner是可以省略的,可写可不写。
一般用inner join on 关键字进行的内连接,又可分为等值连接,非等值连接。
等值连接:条件中只包含“=”时的连接,称之为等值连接。
非等值连接:连接条件中除了等号外,还用了其它的比较运算符(>,<,...),来比较连接列的列值。
外连接特征:至少会返回出一个表的所有内容。
外连接又分为左连接和右连接。
在from的后面,先写的表为左表、后写的表为右表。
1.左连接(left join)
左连接是对左表不加限制,以左表中的数据为基准;使用left outer join 关键字对多个表进行连接,outer可省略不写,左连接的查询结果中包含左表的所有行和右表中的匹配行。若是在右表中找不到匹配行,则使用NULL代替显示。
表1 是左表,连接条件可以是表1.列名1=表2.列名
2.右连接right join
右连接是对右表不加限制,以右表的数据为基准;使用right outer join 关键字对多个表进行连接,右连接返回的是右表的所有行和左表的匹配行,若在左表找不到匹配行,则返回NULL代替显示。
子查询:指的是在查询语句里面嵌套查询语句,子查询语句放在where条件中,子查询的select语句总是使用圆括号括起来。