以下的文章主要讲述的是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则输出两表完全满足条件数据。

转载于:https://www.cnblogs.com/moqiang02/p/4061165.html

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

  1. sql server 关联left join条件on和where条件的区别

    现有两个表,商品表(products)和sales_detail(销售记录表).如下图: products:       pid pname pcode     1   商品1   AC90     ...

  2. mysql 关联查询连接条件

    一.内连接 关键字:inner join on 语句:select * from a_table a inner join b_table b on a.a_id = b.b_id; 说明:组合两个表 ...

  3. mysql inner join where_详解mysql 使用left join添加where条件的问题分析

    当前需求: 有group和factor两张表,一个group对应多个factor,现在想查询有效的group和对应的有效的factor,两个表都有isDel逻辑删除标志. 最开始的错误写法一: SEL ...

  4. mysql关联表id_mysql join联表 + id自增

    join的写法 如果用left join 左边的表一定是驱动表吗?两个表的join包含多个条件的等值匹配,都要写道on还是只把一个写到on,其余写道where部分? createtablea(f1in ...

  5. 详解mysql 使用left join添加where条件的问题分析

    详解mysql 使用left join添加where条件的问题分析 详解mysql 使用left join添加where条件的问题分析

  6. mysql join 算法_【MySQL】之join算法详解

    在阿里巴巴的java开发手册有这么一条强制规定:超过三个表禁止join,需要join的字段,数据类型保持绝对一致,多表关联查询时,要保证被关联的字段需要有索引. 为什么尽量避免使用join?如果使用j ...

  7. mysql 关联更新_跳出初学MySQL知识的原理整理(一)

    一.基础架构 MySQL 可以分为 Server 层和存储引擎层两部分. Server 层包括连接器.查询缓存.分析器.优化器.执行器等,所有跨存储引擎 的功能都在这一层实现,比如存储过程.触发器.视 ...

  8. Mysql关联查询的几种方式(详解)

    在关系型数据库中,要进行多表查询,一般都会使用join连接.join连接的本质其实类似与集合的交并操作,Mysql实现关联查询常见的几种方式如下: 目录 1.左连接 2.右连接 3.内连接 4.全连接 ...

  9. mysql关联表删除、修改数据

    mysql关联表删除.修改数据 关联删除 关联修改 关联删除 -- 多表关联查询删除: -- from 前面用表名的别名才可以,否则会修改失败: DELETE s,u1 FROM stu as s I ...

最新文章

  1. Appium ——Android KEYCODE键值:
  2. jsoncpp使用中的总结
  3. Fedora开启FTP服务
  4. C++字符串详解(三) 字符串的增删改
  5. 重磅:某国产操作系统发布,称完全可替代Windows 7,由华为牵头制作!
  6. 是什么包_包粽子教程,喜欢的收藏,以后想吃什么样的都可以自己包
  7. Interview and paper based test
  8. 改变你人生的,也许只是一个瞬间—顶级互联网公司工作方法
  9. 年入10亿,“山寨”耳机芯片凶猛
  10. Oracle中split功能的实现
  11. Chinese_PRC_CI_AS 和 Chinese_PRC_90_CI_AI 之间的排序规则冲突问题
  12. SQL那些事儿(六)--数据库三大范式
  13. CHAPTER 28 VMX SUPPORT FOR ADDRESS TRANSLATION
  14. Linux进程管理内核API函数pid_task( )---根据pid获取task_struct
  15. 线性代数学习笔记——第二十四讲——向量及其线性运算
  16. obj-c编程11:内存管理和ARC(自动引用计数)
  17. 元宇宙代表人类的倒退
  18. 网络对抗 Exp9 Web安全基础 20154311 王卓然
  19. oracle安装遇到 [INS-20802] Oracle Net Configuration Assistant 失败。
  20. sheel命令学习和工作总结

热门文章

  1. android 八核手机,八核手机
  2. byte数组存的是什么_结构体内存对齐是什么鬼?
  3. Markdown中希腊字母与代码对应表
  4. 我想solo自己一个人!
  5. springcloud 之 配置中心服务 spring cloud config
  6. C/C++语言中字符串多行书写方法
  7. jupyter 共享_可共享的Jupyter笔记本!
  8. ubuntu安装 ftpd server(vsftpd)
  9. 在linux下使用udev获取热插拔(hotplug)事件
  10. 数据管理 - 每天5分钟玩转 Docker 容器技术(147)