当前位置: 首页 > 编程笔记 >

Mysql连接join查询原理知识点

东郭兴学
2023-03-14
本文向大家介绍Mysql连接join查询原理知识点,包括了Mysql连接join查询原理知识点的使用技巧和注意事项,需要的朋友参考一下

Mysql连接(join)查询

1、基本概念

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

假设:

表A有n1行,m1列;

表B有n2行,m2列;

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

n1*n2行;

m1+m2列。

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

3、连接查询基本形式: from  表1  【连接方式】 join  表2  【on连接条件】连接查询基本形式: 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后面的条件)的那些行的数据;

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

2、看内连接的结果:

3、结果为:

4、可见:内连接其实就是找出一个交叉连接的数据结果中,“有意义”的那些数据行。而一个交叉连接,其中的数据,有的有意义,有的没有意义(错误数据)。 

但是,要注意:

  • 1,这种连接条件,不是随意设置,而是要根据表之间的实际关系来设置,通常该关系就是两个表之间的具有“主外键关系”的两个字段的值相等。
  • 2,可见,连接查询,跟我们之前所学的“外键关系”,是有其内在的逻辑一致性的。
  • 3,不过,我们做内连接的时候,并不是要求2个表“必须”有外键关系——我们只是自己从现实角度理解他们有外键关系(数据关系)就可以,而在查询的时候使用内连接就建立起了他们的关系。可见:内连接其实就是找出一个交叉连接的数据结果中,“有意义”的那些数据行。而一个交叉连接,其中的数据,有的有意义,有的没有意义(错误数据)。 
 类似资料:
  • 本文向大家介绍Mysql join连接查询的语法与示例,包括了Mysql join连接查询的语法与示例的使用技巧和注意事项,需要的朋友参考一下 连接查询: 是将两个查询(或表)的每一行,以“两两横同对接”的方式,所得到的所有行的结果,即一个表中的某行,跟另一个表中的某行。进行“横向对接”,得到一个新行。 连接查询包括以下这些不同形式,连接方式: 交叉连接、内连接、外连接(分:左外连接,右外连接)

  • 本文向大家介绍mysql并发控制原理知识点,包括了mysql并发控制原理知识点的使用技巧和注意事项,需要的朋友参考一下 Mysql是主流的开源关系型数据库,提供高性能的数据存储服务。在做后端开发时,有时会遇到性能瓶颈,这些瓶颈有时并不是来自应用本身,而是来自数据库层面。 所以所以掌握Mysql的一些底层原理有助于我们更好地理解Mysql,对Mysql进行性能调优, 从而开发高性能的后端服务。 1、

  • 问题内容: 我想跟随两张桌子 表1:人员 表2:发票 我用这个查询: 但这会产生一个错误 “字段列表”中的未知列“ Persons.Name” MySQL服务器版本为5.5.19,我在Microsoft Windows7中使用了命令行客户端 内联接,右联接和左联接为我工作,但我无法执行完全联接。有什么错误,请告诉我我仍然是学生。我如何在这里执行FULL JOIN? 谢谢你! 问题答案: 为了在my

  • 主要内容:1 关联查询的执行,2 没有索引的算法MySQL的join关联查询的执行过程以及优化手段。 1 关联查询的执行 关联查询的执行过程是:先遍历关联表t1(驱动表,全表扫描),然后根据从表t1中取出的每行数据中的a值,去表t2(被关联表,被驱动表)中查找满足条件的记录,可以走t2的索引搜索。在形式上,这个过程就跟我们写程序时的嵌套查询类似,并且可以用上被驱动表的索引,所以我们称之为“”,简称。在join语句的执行流程中,驱动表是走全表扫描

  • 本文向大家介绍MySQL查询优化必备知识点总结,包括了MySQL查询优化必备知识点总结的使用技巧和注意事项,需要的朋友参考一下 前言 查询优化本就不是一蹴而就的,需要学会使用对应的工具、借鉴别人的经验来对SQL进行优化,并且提升自己。 先来巩固一下索引的优点,检索数据快、查询稳定、存储具有顺序性避免服务器建立临时表、将随机的I/O变为有序的I/O。 但索引一旦创建的不规范就会造成以下问题,占用额外

  • 本文向大家介绍java JVM原理与常识知识点,包括了java JVM原理与常识知识点的使用技巧和注意事项,需要的朋友参考一下 JVM是Java Virtual Machine(Java虚拟机)的缩写,JVM是一种用于计算设备的规范,它是一个虚构出来的计算机,是通过在实际的计算机上仿真模拟各种计算机功能来实现的。Java虚拟机包括一套字节码指令集、一组寄存器、一个栈、一个垃圾回收堆和一个存储方法域