• 首页 首页 icon
  • 工具库 工具库 icon
    • IP查询 IP查询 icon
  • 内容库 内容库 icon
    • 快讯库 快讯库 icon
    • 精品库 精品库 icon
    • 问答库 问答库 icon
  • 更多 更多 icon
    • 服务条款 服务条款 icon

Mysql笛卡尔积附实现多表查询代码实现

武飞扬头像
你不应该热爱
帮助1

前言:实际开发中往往数据来自不同的表,所以需要多表联合查询。多表查询是对多张表的数据取笛卡尔积

1.何为笛卡尔积?

简单来说:就是 简单的 排列组合。

把两张表的记录,放在一起进行排列组合的所有情况。

下面我们通过一个示例来进行说明:

学新通




 排列组合如下:学新通

通过以上可以发现:笛卡尔积的列数就是两个表的列数之和( 3 2 = 5),行数则是两个表的行数之积(2 * 4 = 8 )。因此,需要注意的是:我们在进行多表查询的时候(计算笛卡尔积的过程),如果两个表数据很,就会非常低效,甚至成为危险操作

代码

学新通

Tip(多表情况):如果是三个表的话,那么就是先将两个表进行笛卡尔积运算,再用这个表与另外一个表进行笛卡尔积操作(以此类推)。

a.何为连接条件?

因为毕竟笛卡尔积只是简单的将他们进行排列组合(并没有进行筛选有效信息),我们将有效信息这一筛选的过程称为:连接条件(student.classId = classes.classId)

学新通

 b.联合查询实质

得出结论:多表查询/联合查询 = 笛卡尔积 连接条件 其他条件(具体需求)。 

c.代码实现: 

学新通

join on 实现:

学新通

注意:这里都有相同的记录名(classId),所以这里通过 表名.列名 的方法实现,如果不用则会报错:

学新通

这篇好文章是转载于:学新通技术网

  • 版权申明: 本站部分内容来自互联网,仅供学习及演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,请提供相关证据及您的身份证明,我们将在收到邮件后48小时内删除。
  • 本站站名: 学新通技术网
  • 本文地址: /boutique/detail/tanhfjijii
系列文章
更多 icon
同类精品
更多 icon
继续加载