`
moqiang02
  • 浏览: 561125 次
  • 性别: Icon_minigender_1
  • 来自: 苏州
文章分类
社区版块
存档分类
最新评论

MySQL关联left join 条件on与where不同

 
阅读更多

以下的文章主要讲述的是MySQL关联left join 条件on与where 条件的不同之处,我们现在有两个表,即商品表(products)与sales_detail(销售记录表)。我们主要是通过这两个表来对MySQL关联left join 条件on与where 条件的不同之处进行讲述。

products:

pid pname pcode

1 商品1 AC90

2 商品2 DE78

3 商品3 XXXX

sales_detail:  
aid pcode saletime  
1 AC90 2008-09-22  
2 DE78 2008-09-22  
3 AC90 2008-09-23  
4 AC90 2008-09-24 
某个时间段内的销售量来排行,比如我想统计23-24号这两天的销售数量并排行。(注:DE78这个商品在这两天没有销售,但是也要显示出来,只是数量为0)。

MySQL关联left join条件on和where条件的区别表的结构 `products`

CREATE TABLE `products` (  
`pid` int(3) NOT NULL auto_increment,  
`pname` varchar(20) NOT NULL,  
`pcode` varchar(20) NOT NULL,  
PRIMARY KEY (`pid`)  
) ENGINE=MyISAM AUTO_INCREMENT=1 DEFAULT CHARSET=utf8; 

导入表中的数据 `products`

INSERT INTO `products` (`pid`, `pname`, `pcode`) VALUES 
(1, '商品1', 'AC90'),  
(2, '商品2', 'DE78'),  
(3, '商品3', 'XXXX'); 
表的结构 `sales_detail`

CREATE TABLE `sales_detail` (  
`aid` int(3) NOT NULL auto_increment,  
`pcode` varchar(20) NOT NULL,  
`saletime` date NOT NULL,  
PRIMARY KEY (`aid`)  
) ENGINE=MyISAM DEFAULT CHARSET=utf8 AUTO_INCREMENT=1; 
表中的数据 `sales_detail`

INSERT INTO `sales_detail` (`aid`, `pcode`, `saletime`) VALUES 
(1, 'AC90', '2008-09-22'),  
(2, 'DE78', '2008-09-22'),  
(3, 'AC90', '2008-09-23'),  
(4, 'AC90', '2008-09-24'); 

MySQL关联left join条件on和where条件的区别区别两条sql语句:

select p.pname,p.pcode,s.saletime,count(s.aid) as total 
from products as p  left join sales_detail as s 
on (s.pcode=p.pcode)  
where s.saletime in ('2008-09-23','2008-09-24')   
group by p.pcode 
order by total desc,p.pid asc

+-------+-------+------------+
| pname | pcode | saletime   |
+-------+-------+------------+
| 商品1 | AC90  | 2008-09-23 |
+-------+-------+------------+

select p.pname,p.pcode,s.saletime,count(s.aid) as total 
from products as p  left join sales_detail as s 
on ((s.pcode=p.pcode) and s.saletime in ('2008-09-23','2008-09-24'))   
group by p.pcode 
order by total desc,p.pid asc

+-------+-------+------------+-------+
| pname | pcode | saletime   | total |
+-------+-------+------------+-------+
| 商品1 | AC90  | 2008-09-23 |     2 |
| 商品2 | DE78  | NULL       |     0 |
| 商品3 | XXXX  | NULL       |     0 |
+-------+-------+------------+-------+ 

心得:on中的条件关联,一表数据不满足条件时会显示空值。where则输出两表完全满足条件数据。

分享到:
评论

相关推荐

    解析mysql left( right ) join使用on与where筛选的差异

    MySQL中的LEFT JOIN和RIGHT JOIN是进行表连接查询的两种常见方式,它们用于在两个表之间根据一定的条件进行数据匹配。LEFT JOIN称为左连接,它会返回左表(即第一个表)的所有记录,以及右表(即第二个表)匹配的...

    MySQL left join操作中on和where放置条件的区别介绍

    如果`WHERE` 子句包含的条件与`LEFT JOIN`的连接条件相同,但放在`WHERE`里,那么这个条件将在临时表生成后才被检查,这可能导致左表的某些行因不满足`WHERE`条件而被过滤掉,失去了`LEFT JOIN`应有的效果。...

    深入理解mysql之left join 使用详解

    ON 子句与 WHERE 子句的不同 一种更好地理解带有 WHERE … IS NULL 子句的复杂匹配条件的简单方法 Matching-Conditions 与 Where-conditions 的不同 关于 “A LEFT JOIN B ON 条件表达式” 的一点提醒 ON 条件(...

    sql中的left join及on、where条件关键字的区别详解

    LEFT JOIN 关键字会从左表 (table_name1) 那里返回所有的行,即使在右表 (table_name2) 中没有匹配的行。 LEFT JOIN 关键字语法 SELECT column_name(s) FROM table_name1 LEFT JOIN table_name2 ON table_name1....

    mysql中left join设置条件在on与where时的用法区别分析

    在MySQL中,LEFT JOIN操作用于将一个表(称为左表)的所有记录与另一个表(称为右表)中匹配的记录组合在一起。如果右表中没有匹配的记录,结果集将包含左表的所有记录,但右表对应列的值将为NULL。当我们设置LEFT ...

    Mysql之innerjoin,leftjoin,rightjoin详解.pdf

    Mysql 之 inner join、left join、right join 详解 Mysql 中的连接查询是指从多个表中检索数据,并将它们组合成一个结果集。inner join、left join 和 right join 是 Mysql 中三种最常用的连接查询方式。 inner ...

    mysql多个left join连接查询用法分析

    MySQL中的LEFT JOIN是一种关联多个表的方法,用于返回左表的所有记录以及右表匹配的记录。在某些场景下,我们可能需要连接多个表来获取全面的数据信息。本篇文章将深入探讨MySQL多个LEFT JOIN连接查询的用法,通过...

    mysql Join使用以及优化

    MySQL数据库中Join操作的使用及优化是一项重要的技能,它涉及到数据库中表与表之间的关联查询。在执行Join操作时,数据库管理系统需要按照某种算法将多个表中的数据记录联合起来,并返回查询结果。Join操作的主要...

    MySQL表LEFT JOIN左连接与RIGHT JOIN右连接的实例教程

    与LEFT JOIN相反,RIGHT JOIN会返回右表的所有记录,即使在左表中没有匹配的记录。在上述文章和用户表的例子中,如果我们想要列出所有用户,以及他们可能拥有的文章,即使某些用户没有发表过文章,可以使用RIGHT ...

    mysql not in、left join、IS NULL、NOT EXISTS 效率问题记录

    MySQL中的`NOT IN`, `LEFT JOIN`, `IS NULL`, 和 `NOT EXISTS` 是四种不同的SQL查询方式,它们在特定情况下可以实现相似的功能,但实际执行效率可能会有很大差异。本文主要探讨这四种方法在处理大数据量时的性能表现...

    MySQL查询条件中放置on和where的区别分析

    在MySQL查询中,`ON` 和 `WHERE` 都是用来设置查询条件的,但它们在不同的语句结构中起着不同的作用。理解这两者之间的差异对于编写高效的SQL查询至关重要。 首先,`ON` 关键字主要用于`JOIN`操作,如`INNER JOIN`,...

    MySQL的LEFT JOIN表连接的进阶学习教程

    MySQL的LEFT JOIN是一种关联查询操作,它用于合并两个或多个表的数据,并且返回所有左表(也就是在JOIN语句中位于LEFT关键字之后的表)的记录,即使在右表中没有匹配的记录。这个概念是数据库关系查询中的关键部分,...

    解决在laravel中leftjoin带条件查询没有返回右表为NULL的问题

    然而,在Laravel的Eloquent ORM中,如果直接使用`leftJoin`和`where`方法,会导致行为与原生SQL不一致,因为`where`方法实际上会应用一个内部的INNER JOIN逻辑,从而丢失了左连接的意义。正确的写法应该是将筛选条件...

    mysql_adv_select.rar_any left join_union

    结合使用`LEFT JOIN`和`UNION ALL`,我们可以构造一个复杂的查询,首先使用`LEFT JOIN`从文章表中获取数据,并关联到分类表以获取对应的分类名称,然后通过`UNION ALL`将不同条件下的查询结果整合在一起。...

Global site tag (gtag.js) - Google Analytics