mysql left( right ) join 使用on 与where的差异

之前一直很困扰为什么left join要么一查没有数据,要么出现很多条重复数据。

百思不得其解,后来在网上到处找资料,总算明白了。

一定要理解下面几点:

 (1)主表条件在on后面时附表只取满足主表筛选条件的值、而主表还是取整表。

(2)对于主表的筛选条件应放在where后面,不应该放在ON后面

(3)对于关联表我们要区分对待。如果是要条件查询后才连接应该把查询件

              放置于ON后。

              如果是想再连接完毕后才筛选就应把条件放置于where后面

(4) 对于关联表我们其实可以先做子查询再做join

--------------------下面2个sql最后得到的结果是不一样的

select a.*,d.UserName
from T_Letter a
left join T_User d on a.UserID=d.UserID

and d.UserName =‘777‘   //条件查询后才连接 查询件放置于ON后

select a.*,d.UserName
from T_Letter a
left join T_User d on a.UserID=d.UserID

where d.UserName =‘777‘    //连接完毕后才筛选 条件放置于where后面

时间: 2024-10-30 19:52:55

mysql left( right ) join 使用on 与where的差异的相关文章

mysql left/right join on 和where的细小差异

总是在暴漏出bug的时候,才发现自己对知识掌握的不深入. 存在两张表结构 drop table if EXISTS A; CREATE TABLE A ( ID int(1) NOT NULL, PRIMARY KEY (ID) ) ENGINE=MyISAM DEFAULT CHARSET=utf8; insert into A values ( 1 ); insert into A values ( 2 ); insert into A values ( 3 ); insert into A

MySQL关联left join 条件on与where不同,很实用,但要慎用

在mysql查询中,有时候业务复杂了,不得不写多表查询:很多程序猿前期都喜欢写子查询,因为子查询简单易懂,不容易出问题,但子查询的效率毕竟不如关联查询:关联查询我觉得是把双刃剑,在不懂它的机制时,还是慎用,我碰到过以前的同事,因为关联查询没写好,把奖品(查询活动中奖信息)发错的,还好大奖不是汽车: 网上摘的例子,比较好理解 MySQL关联left join条件on和where条件的区别表的结构 `products` CREATE TABLE `products` ( `pid` int(3) N

mysql的left join使用on与where筛选的差异

举例进行说明,我们现在有两个表,即商品表(products)与sales_detail(销售记录表).我们主要是通过这两个表来对MySQL关联left join 条件on与where 条件的不同之处进行讲述. 1.数据准备 创建products表并插入数据 drop table if exists products; CREATE TABLE `products` ( `pid` INT (3) NOT NULL auto_increment, `pname` VARCHAR (20) NOT

MySQL的left join中on与where的区别

关于 “A LEFT JOIN B ON 条件表达式” 的一点提醒 ON 条件(“A LEFT JOIN B ON 条件表达式”中的ON)用来决定如何从 B 表中检索数据行,即使on中包含有A表中的列的限制条件,也不会过滤A的任何数据(A的数据只会通过where过滤). 如果 B 表中没有任何一行数据匹配 ON 的条件,将会额外生成一行所有列为 NULL 的数据 在匹配阶段 WHERE 子句的条件都不会被使用.仅在匹配阶段完成以后,WHERE 子句条件才会被使用.它将从匹配阶段产生的数据中检索过

mysql innerjoin left join right join 解析

毕业半年多时间,一直都没有学习好join  之前一直是先从一个表里面取出数据然后,然后再从另外一个表里面取出数据,然后再写一个函数循环格式化数据. 还是先写一下学到的东西吧! 转载自w3school Join 和 Key 有时为了得到完整的结果,我们需要从两个或更多的表中获取结果.我们就需要执行 join. 数据库中的表可通过键将彼此联系起来.主键(Primary Key)是一个列,在这个列中的每一行的值都是唯一的.在表中,每个主键的值都是唯一的.这样做的目的是在不重复每个表中的所有数据的情况下

【转】Mysql之inner join,left join,right join详解

首先借用官方的解释下: inner join(等值连接):只返回两个表中联结字段相等的行: left join(左联接):返回包括左表中的所有记录和右表中联结字段相等的记录: right join(右联接):返回包括右表中的所有记录和左表中联结字段相等的记录. 比如我们有xs.cj两个表 xs表 cj表 --------------- ---------------------- id name id score 1 张三 1 96 2 李四 2 80 3 86 Sql代码 1 SELECT *

性能调优:mysql之left join

poptest是国内唯一一家培养测试开发工程师的培训机构,以学员能胜任自动化测试,性能测试,测试工具开发等工作为目标.如果对课程感兴趣,请大家咨询qq:908821478,咨询电话010-84505200. 需求是一个普通的两个表连接从而查询出详细信息.其中A表是大表, 测试数据都有数万条: B表是小表大概1000多条数据. 1. 为了赶工写出的未优化SQL(为突出主题, 返回字段用 * 代替不写出详细字段, WHERE条件也去掉了): SELECT * FROM A a LEFT JOIN B

mysql关键字讲解(join 、order by、group by、having、distinct)

1.join     1.1 OUTER JOIN:想要包含右侧表中的所有行,以及左侧表中有匹配记录的行.        1.11 Mysql中有左连接(left join):             SELECT * FROM a LEFT JOIN  b ON a.aID =b.bID             left join是以A表的记录为基础的,A可以看成左表,B可以看成右表,left join是以左表为准的.         1.12 右连接(right join):        

mysql 跨库JOIN

现有两台MYSQL数据库 一台是192.168.1.1 端口3306 上有数据库DB1 有表TABLE1一台是192.168.1.2 端口3307 上有数据库DB2 有表TABLE2192.168.1.1远程连接192.168.1.2数据库所使用的用户名root1 密码root1 192.168.1.2远程连接192.168.1.1数据库所使用的用户名root2 密码root2现在想对 TABLE1 和 TABLE2 两张表进行关联查询 请问SQL应该怎么实现 没有办法直接进行JOIN查询. 你