php mysql join查询_Mysql中关于连接(join)查询详解

Mysql中关于连接(join)查询详解

1.基本概念

将两个表的每一行,以“两两横向对接”的方式,所得到的所有行的结果。

假设:

表A有n1行,m1列;

表B有n2行,m2列;

则表A和表B“对接”之后,就会有:

n1*n2行;

m1+m2列。

43fc8c1ef153c2f3854523ee13422727.png

2.则他们对接(连接)之后的结果类似这样:

bb172a123620460a10f58b86109917c6.png

3连接查询基本形式:

from 表1 【连接方式】 join 表2 【on连接条件】

连接查询的分类

1.交叉连接

其实就是两个表之间按连接的基本概念,进行连接之后所得到的“所有数据”,而对此无任何“筛选”的结果——筛选就是指连接条件。

即:交叉连接就是没有条件的“全部连接”——有称为 笛卡尔积。

交叉连接通常没有实用价值,因为这样连接之后 数据,每一行数据的意义就可能会“丢失”。

形式:

from 表1 【cross】 join 表2 ;

或:

from 表1 , 表2 ;

内连接

形式:

from 表1 【inner】 join 表2 on 表1.字段1 = 表2.字段2;

含义:

取得一个“交叉连接”的结果中,满足所设定的连接条件(就是on后面的条件)的那些行的数据;

交叉连接往往会有“无意义数据”,如下:

f927aa90ec8d580856be51202e81fcc8.png

2.看内连接的结果:

54fd9441b8e5cb8eaf5be5e3b731dc75.png

3.结果为:

3aa0845cb13228f07e68487afab8e232.png

4.可见:

内连接其实就是找出一个交叉连接的数据结果中,“有意义”的那些数据行。

而一个交叉连接,其中的数据,有的有意义,有的没有意义(错误数据)。

但是,要注意:

1,这种连接条件,不是随意设置,而是要根据表之间的实际关系来设置,通常该关系就是两个表之间的具有“主外键关系”的两个字段的值相等。

2,可见,连接查询,跟我们之前所学的“外键关系”,是有其内在的逻辑一致性的。

3,不过,我们做内连接的时候,并不是要求2个表“必须”有外键关系——我们只是自己从现实角度理解他们有外键关系(数据关系)就可以,而在查询的时候使用内连接就建立起了他们的关系。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值