首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

MYSQL多表联合查询

于此对应的是我们在进行后台的丰富数据查询时就需要合并表进行查询,今天特意整理一下使用JOIN进行多表联合查询的注意点。...在多表查询时,我们会遇到某个表 对应项目为空时的情况, 这时根据JOIN方式就会有不同的结果。...看三个对比: # JOIN 多表条件查询 # 靠后的表会是左右的反方向追加进来 # case1 SELECT * FROM user_account LEFT JOIN user_info ON user_account.userid...屏蔽数据表内AND 过滤筛选WHERE最后 虽然我们可以用INNER+表内条件的方式来进行筛选,但是这里推荐的是 如果要筛选就全部写在WHERE语句中,这样在查询的时候MYSQL会优化查询减少整体的运算量...这个时候我们不可避免的还是要使用联合查询。 可以优化的就是将不参与筛选的表从中移除,这样以便于优化查询效率。

2.7K40
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    MySQL多表联合查询

    1、多表联合查询 1.1 什么是多表联合查询 多表联合查询就是同时查询两个或两个以上的表。 在 MySQL 中,多表联合查询主要有交叉连接、内连接、外连接、分组查询与子查询等5种。...总结 多表查询遵循的算法就是笛卡尔积,表与表之间的连接可以看成是在做乘法运算。在实际应用中,应避免使用笛卡尔积,因为笛卡尔积中容易存在大量的不合理数据,简单来说就是容易导致查询结果重复、混乱。...所以,通过交叉连接的方式进行多表查询的这种方法并不常用,我们应该尽量避免这种查询。...建议 在 MySQL 中,多表查询一般使用内连接和外连接,它们的效率要高于交叉连接。...因此,在多表查询时,SELECT 语句后面的写法是表名.列名。 如果表名非常长的话,也可以给表设置别名,这样就可以直接在 SELECT 语句后面写上表的别名.列名。

    10.5K50

    sql多表联合查询详解_sql多表查询例子

    sql语句会用到许多查询语句,如果牵扯到多张表的时候 一般会需要复杂查询方式: 嵌套查询: select * from bi_BillItem where BillID in (select...count ,from where,in ,and,group up都是关键字,这条语句的意思是:bi_BillItem根据billid去bill表查满足这些条件的如果查到满足条件billid相等的就查询出...bi_BillItem中的menuId,menuName,MenuPrice,(sum(AmountOrder)-sum(AmountCancel))字段 并且按 menuId和menuPrice排序 多表联合查询...bi_BillItem.BillID=bi_Bill.BillID where IsArchived='0' and IsCheckOuting='2' group by menuId,MenuPrice 这条语句 也叫做多表关联查询...他们之间差别是 查询数据过多时,多表联合查询比嵌套查询 速度快很多 。

    2.3K20

    Mybatis高级查询(二):多表联合查询

    Mybatis高级查询(二) 多表查询 准备工作 新建一个Maven工程 添加依赖 <!...所谓的一对一就是查询的那张表只关联一张表 在OrdersMapper中添加一个接口方法 /** * 使用resultType查询订单表和用户表 * @param orders * @return...-- 使用resultType查询订单和用户表(一对一查询)--> <select id="findOrdersUserResultMap" resultMap="OrderUserResultMap...一对多就是<em>查询</em>的那张表对应多个表或者<em>查询</em>的那张表他对应的表对应多张表 在OrdersMapper接口中添加一个接口方法 /** * <em>联合</em><em>查询</em>(一对多)<em>查询</em>订单表和用户表和订单明细 * @param...-- 一对多<em>查询</em> 订单表关联用户表,订单明细表--> <!

    1.3K30

    理解mysql执行多表联合查询

    , union; 3) 交叉连接:cross join join的含义是:用于多表中字段直接的联系。...user表和user2表(内连接) 通过on后面的条件查询,user表中的age字段 等于 user2表中的age这个条件满足的话,才会把两个表中的数据都查询出来的,否则的话,查询数据就是空哦。...or的意思,第二个条件是使用 right join 连接符,意思是如果username字段不相等的话,就按照第二张表的数据全部查询出来,第一张表的所有字段查询值为null。...如下所示: image.png 六:node+mysql 多表联合查询 在mysql模块中,我们可以使用Connection对象的query方法的第一个参数编写sql语句来执行多表联合查询,但是如果在...我们是想要把这两张表的数据同时查询出来。

    2K41

    MyBatis 多表联合查询及优化

    序 这篇文章我打算来简单的谈谈 mybatis 的多表联合查询。...但是吧,就我前几天在做一个多表联合查询的时候,竟然出了很多意想不到的问题,而且这些问题的出现,并不是对 mybatis 不了解,而是在用的过程中会或多或少的忽略一些东西,导致提示各种错误。...索性这几天有时间,就做了一个小 Demo ,实现 mybatis 的多表联合查询的,由于之前用的是 Hibernate 做的联合查询,众所周知,Hibernate 是全自动的数据库持久层框架,它可以通过实体来映射数据库...正文 下面就来说一下 mybatis 是通过什么来实现多表联合查询的。...由于是测试多表联合查询,因此需要自己稍加改动。

    1.1K10

    SQL语法(五) 多表联合查询

    前言 当需要获取的数据分布在多张中,考虑使用联合查询,本章将学习两种查询方式(sql92/sql99) 范例 1.笛卡儿积 将多个表的数据进行一一对应,所得到结果为多表的笛卡尔积。...–SQL92方式 –表名以逗号隔开实现多表查询 –SQL99方式 –使用cross join 关键字 2.等值连接筛选&不等值连接筛选(内连接) –概念:先做表的笛卡尔积,然后筛选,筛选条件为等值筛选...满外连接 –SQL92方式 无 –SQL99方式 –select 内容 from 表名 full (outer) join 表名 on 连接条件 (外连接,outer可以省略不写) 附录:多表联合查询示例...(SQL99) --查询所有数据 select * from EMP for update; --笛卡尔积 (1,2,3) (5,6,7) --SQL92,SQL99(推荐) --使用 cross join...aid=62084547 SQL语法之多表联合查询 发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/131535.html原文链接:https://javaforall.cn

    3K10

    【MySQL】多表联合查询、连接查询、子查询「建议收藏」

    文章目录 【1】连接查询 内连接查询 外连接查询 左连接 右连接 【2】联合查询 【3】子查询 带in关键字的子查询 带比较运算符的子查询 带exists的子查询 带any关键字的子查询 带all关键字的子查询...select a.id,a.name,a.addrid,b.country,b.city from student a right join addr b on a.addrid=b.addrid; 【2】联合查询...联合查询 联合查询结果是将多个select语句的查询结果合并到一块因为在某种情况下需要将几个select语句查询的结果合并起来显示。...: 查询同一张表,但是需求不同 如查询学生信息, 男生身高升序, 女生身高降序 多表查询: 多张表的结构是完全一样的,保存的数据(结构)也是一样的....联合查询order by的使用 在联合查询中: order by不能直接使用(不能出现两次),需要对查询语句使用括号才行; select *from student where sex="woman

    4.7K20

    【MySQL数据库】多表关系与多表联合查询

    目录 MySQL多表关系 一对一 一对多 多对多 MySQL外键约束 创建外键 数据插入 删除 多表联合查询 交叉连接查询 内连接查询 外连接查询查询关键字 自关联 MySQL多表关系 MySQL...添加主表数据 -- 注意必须先给主表添加数据 添加从表数据 -- 注意给从表添加数据时,外键列的值不能随便写,必须依赖主表的主键列 删除 主表的数据被从表依赖时,不能删除,否则可以删除 从表的数据可以随便删除 多表联合查询...子查询就是指的在一个完整的查询语句之中,嵌套若干个不同功能的小查询,从而一起完成复杂查询的一种编写形式,通俗一点就是包含select嵌套的查询。...ALL表示指定列中的值必须要大于子查询集的每一个值,即必须要大于子查询集的最大值;如果是小于号即小于子查询集的最小值。同理可以推出其它的比较运算符的情况。...EXISTS 该子查询如果“有数据结果”(至少返回一行数据), 则该EXISTS() 的结果为“true”,外层查询执行 该子查询如果“没有数据结果”(没有任何数据返回),则该EXISTS()的结果为

    2.7K20

    【MySQL数据库】多表关系与多表联合查询

    ​​目录MySQL多表关系一对一一对多多对多MySQL外键约束创建外键数据插入删除多表联合查询交叉连接查询内连接查询外连接查询查询关键字自关联MySQL多表关系MySQL表与表之间的三种关系一对多关系...数据插入添加主表数据 -- 注意必须先给主表添加数据添加从表数据 -- 注意给从表添加数据时,外键列的值不能随便写,必须依赖主表的主键列删除主表的数据被从表依赖时,不能删除,否则可以删除从表的数据可以随便删除多表联合查询​编辑...,嵌套若干个不同功能的小查询,从而一起完成复杂查询的一种编写形式,通俗一点就是包含select嵌套的查询。...ALL表示指定列中的值必须要大于子查询集的每一个值,即必须要大于子查询集的最大值;如果是小于号即小于子查询集的最小值。同理可以推出其它的比较运算符的情况。...), 则该EXISTS() 的结果为“true”,外层查询执行该子查询如果“没有数据结果”(没有任何数据返回),则该EXISTS()的结果为“false”,外层查询不执行EXISTS后面的子查询不返回任何实际数据

    3K30

    Oracle函数学习(多表联合查询

    多表联合查询: –当需要获取的数据分布在多张中,考虑使用联合查询 –SQL92方式 –SQL99方式 –SQL99多表查询 –注意1:依然可以给表添加别名 –注意2:如果使用on或者usering...排序等 –笛卡尔积:使用cross join 关键字 —select 内容 from 表名 cross join select * from emp cross join dept –筛选 –查询员工姓名...select * from emp natural join dept –解决1:使用using关键字 –作用1:指明使用指定的字段对联合查询的结果进行等值筛选 –注意:指明的字段必须是两表的同名同值字段...emp.deptno=dept.deptno where sal>2000 –外连接: –左外连接:select 内容 from 表名 left outer join 表名 on 连接条件 –查询员工姓名...left outer join dept d on e.deptno=d.deptno –右外连接:select 内容 from 表名 right outer join 表名 on 连接条件 –查询员工姓名

    1.1K10

    数据库之多表联合查询

    一、知识点名称 多表联合查询(一对多数据显示、多对多数据展示) 二、知识点业务场景 一对多关联: 学生和成绩的关系 用户与订单的关系 企业与员工的关系...多对多关联: 学生和选课的关系 订单和商品的关系 用户和角色的关系 角色和权限的关系 三、知识点业务(原理) a、多表联合查询的原理...例如下面: b、多表联合查询的不同方式 1、交叉连接 交叉连接即是笛卡尔积,是指两个关系中所有元组的任意组合。一般情况下,交叉查询是没有实际意义的。...内连接查询实际上是一种任意条件的查询。使用内连接时,如果两个表的相关字段满足 连接条件,就从这两个表中提取数据并组合成新的记录,也就是在内连接查询中,只有满足条件的元组才能出现在结果关系中。...3、自连接 如果在一个连接查询中,涉及到的两个表都是同一个表,这种查询就称为自连接查询。同一张表在FROM字句中对多次 出现,为了区别该表的每一次出现,需要为表定义一个别名。

    2.3K20

    SQL 多表联合查询的几种方式

    通过连接运算符可以实现多个表查询。 正文 连接查询主要分为三种:内连接、外连接、交叉连接。 内连接 使用比较运算符(包括=、>、、>=、 和!...关键字 INNER JOIN 等值连接/相等连接 使用”=”关系将表连接起来的查询,其查询结果中列出被连接表中的所有列,包括其中的重复列 SELECT PM_ACT_JOB_RLS.*,...,设计到的两个表都是同一个表,这种查询称为自连接查询。...OUTER JOIN MM_LOT_OPERATIONS AS mo ON me.LotID = mo.SerialNumber 注意: left join中关于where和on条件的几个知识点: 多表...当数据量比价大的时候,笛卡尔积操作会很消耗数据库的性能 总结 连接查询是关系型数据库中的一个重要标志,这次和大家一起复习多表查询的几种操作,希望给您带来帮助!

    75220

    MySQL 多表联合查询有何讲究?

    今天我们来聊聊微信中的多表联合查询,应该是小表驱动大表还是大表驱动小表? 1. in VS exists 在正式分析之前,我们先来看两个关键字 in 和 exists。...假设我现在想查询技术部的所有员工,我有如下两种查询方式: 第一种查询方式是使用 in 关键字来查询: select * from employee e where e.departmentId in(select...查询的时候也是先查询里边的子查询(即先查询 department 表),然后再执行外表的查询,我们可以看下它的执行计划: 可以看到,首先查询部门表,有索引就用索引,没有索引就全表扫描,然后查询员工表,...为什么要小表驱动大表 在 MySQL 中,这种多表联合查询的原理是:以驱动表的数据为基础,通过类似于我们 Java 代码中写的嵌套循环 的方式去跟被驱动表记录进行匹配。...不过老实说,这种没有索引的多表联合查询效率比较低,应该尽量避免。 综上所述,在多表联合查询的时候,建议小表驱动大表。

    2.1K20
    领券