推广 热搜: 行业  机械  设备    系统  教师  经纪    参数  蒸汽 

MySQL中多表查询、表连接(内连接和外连接)

   日期:2024-11-19     移动:http://gzhdwind.xhstdz.com/mobile/quote/80753.html

文章目录

MySQL中多表查询、表连接(内连接和外连接)

表与表的关系

一对一关系

一对多关系

多对多关系

表与表之间的连接

笛卡尔积

什么是笛卡尔积

内连接

1、通过where关键字进行关联

2、通过inner join on进行关联

外连接

1.左连接(left join

2.右连接right join

子查询


有时候我们所需要的数据不止在一张表中,需要多个表做结合的查询,这时就需要进行表连接。

多表连接主要需要决定关系:方向性、主附关系

在一对一关系中,A表中的一行最多只能匹配B表中的一行,反之亦然,创建的就是一对一关系。

MySQL中多表查询、表连接(内连接和外连接)

一对多关系是最常见的一种关系,A表中的一行可以匹配B表中的多行,但是B表中的一行只能匹配A表中的一行。

例如:存在部门表和人员表之间具有一对多的关系,每个部门有很多的员工,但是每个员工只属于一个部门

只有当一个相关列是一个主键或者具有唯一性约束时,才能创建一对多的关系。

MySQL中多表查询、表连接(内连接和外连接)

在多对多的关系中,A表中一行可以匹配B表中的多行,反之亦然。

要创建这种关系,需要定义第三张表,称之为结合表,他的主键由A表和B表外部键组成

 MySQL中多表查询、表连接(内连接和外连接)

什么是笛卡尔积

数学上,有两个集合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 加入有效的连接条件

消除笛卡尔积:使用等值连接和非等值连接

内连接称之为普通连接或自然连接,按照连接条件,返回两张表中的满足条件的记录。

内连接查询的特征:只关联表与表中能够匹配到的数据信息,才能有对应的查询结果,如图所示

MySQL中多表查询、表连接(内连接和外连接)

 内连接提供了两种表与表之间的连接方式

1、通过where关键字进行关联

 

注意

  • 表与表之间建立起关联的列,列名可以不一样,但是这两个列的数据类型内容必须保持一致
  • 要查询的字段,必须要在字段的前面加上表名或者表的别名

2、通过inner join on进行关联

inner是可以省略的,可写可不写。

 

一般用inner join  on 关键字进行的内连接,又可分为等值连接非等值连接

等值连接:条件中只包含“=”时的连接,称之为等值连接。

非等值连接:连接条件中除了等号外,还用了其它的比较运算符(>,<,...,来比较连接列的列值。

外连接特征至少会返回出一个表的所有内容。

外连接又分为左连接和右连接。

在from的后面,先写的表为左表、后写的表为右表。

1.左连接(left join

左连接是对左表不加限制,以左表中的数据为基准;使用left outer join 关键字对多个表进行连接,outer可省略不写,左连接的查询结果中包含左表的所有行和右表中的匹配行。若是在右表中找不到匹配行,则使用NULL代替显示。

MySQL中多表查询、表连接(内连接和外连接)

 

表1 是左表,连接条件可以是表1.列名1=表2.列名

2.右连接right join

右连接是对右表不加限制,以右表的数据为基准;使用right outer join 关键字对多个表进行连接,右连接返回的是右表的所有行和左表的匹配行,若在左表找不到匹配行,则返回NULL代替显示。

 
 

子查询:指的是在查询语句里面嵌套查询语句,子查询语句放在where条件中,子查询的select语句总是使用圆括号括起来。

本文地址:http://gzhdwind.xhstdz.com/quote/80753.html    物流园资讯网 http://gzhdwind.xhstdz.com/ , 查看更多

特别提示:本信息由相关用户自行提供,真实性未证实,仅供参考。请谨慎采用,风险自负。


0相关评论
相关最新动态
推荐最新动态
点击排行
网站首页  |  关于我们  |  联系方式  |  使用协议  |  版权隐私  |  网站地图  |  排名推广  |  广告服务  |  积分换礼  |  网站留言  |  RSS订阅  |  违规举报  |  鄂ICP备2020018471号