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则输出两表完全满足条件数据。
转载于:https://www.cnblogs.com/moqiang02/p/4061165.html
MySQL关联left join 条件on与where不同相关推荐
- sql server 关联left join条件on和where条件的区别
现有两个表,商品表(products)和sales_detail(销售记录表).如下图: products: pid pname pcode 1 商品1 AC90 ...
- mysql 关联查询连接条件
一.内连接 关键字:inner join on 语句:select * from a_table a inner join b_table b on a.a_id = b.b_id; 说明:组合两个表 ...
- mysql inner join where_详解mysql 使用left join添加where条件的问题分析
当前需求: 有group和factor两张表,一个group对应多个factor,现在想查询有效的group和对应的有效的factor,两个表都有isDel逻辑删除标志. 最开始的错误写法一: SEL ...
- mysql关联表id_mysql join联表 + id自增
join的写法 如果用left join 左边的表一定是驱动表吗?两个表的join包含多个条件的等值匹配,都要写道on还是只把一个写到on,其余写道where部分? createtablea(f1in ...
- 详解mysql 使用left join添加where条件的问题分析
详解mysql 使用left join添加where条件的问题分析 详解mysql 使用left join添加where条件的问题分析
- mysql join 算法_【MySQL】之join算法详解
在阿里巴巴的java开发手册有这么一条强制规定:超过三个表禁止join,需要join的字段,数据类型保持绝对一致,多表关联查询时,要保证被关联的字段需要有索引. 为什么尽量避免使用join?如果使用j ...
- mysql 关联更新_跳出初学MySQL知识的原理整理(一)
一.基础架构 MySQL 可以分为 Server 层和存储引擎层两部分. Server 层包括连接器.查询缓存.分析器.优化器.执行器等,所有跨存储引擎 的功能都在这一层实现,比如存储过程.触发器.视 ...
- Mysql关联查询的几种方式(详解)
在关系型数据库中,要进行多表查询,一般都会使用join连接.join连接的本质其实类似与集合的交并操作,Mysql实现关联查询常见的几种方式如下: 目录 1.左连接 2.右连接 3.内连接 4.全连接 ...
- mysql关联表删除、修改数据
mysql关联表删除.修改数据 关联删除 关联修改 关联删除 -- 多表关联查询删除: -- from 前面用表名的别名才可以,否则会修改失败: DELETE s,u1 FROM stu as s I ...
最新文章
- Appium ——Android KEYCODE键值:
- jsoncpp使用中的总结
- Fedora开启FTP服务
- C++字符串详解(三) 字符串的增删改
- 重磅:某国产操作系统发布,称完全可替代Windows 7,由华为牵头制作!
- 是什么包_包粽子教程,喜欢的收藏,以后想吃什么样的都可以自己包
- Interview and paper based test
- 改变你人生的,也许只是一个瞬间—顶级互联网公司工作方法
- 年入10亿,“山寨”耳机芯片凶猛
- Oracle中split功能的实现
- Chinese_PRC_CI_AS 和 Chinese_PRC_90_CI_AI 之间的排序规则冲突问题
- SQL那些事儿(六)--数据库三大范式
- CHAPTER 28 VMX SUPPORT FOR ADDRESS TRANSLATION
- Linux进程管理内核API函数pid_task( )---根据pid获取task_struct
- 线性代数学习笔记——第二十四讲——向量及其线性运算
- obj-c编程11:内存管理和ARC(自动引用计数)
- 元宇宙代表人类的倒退
- 网络对抗 Exp9 Web安全基础 20154311 王卓然
- oracle安装遇到 [INS-20802] Oracle Net Configuration Assistant 失败。
- sheel命令学习和工作总结