MySQL多个条件以什么表当做主条件表_20161111周五
前两天有事情 停了2天
数据需求:
1、活动日期11.8-11.10订单
2、单笔订单购买A类产品 B类产品满足68元、且连续3天下单的用户ID
首先第一个条件很简单,主要是第二个条件 第二个条件是 且 逻辑运算
并且计算每个字段维度也不一样,单笔订单购买A、B 满足68 这个情况包含一个用户一天下多个订单 这个是一个用户多条记录的情况 我称之为多对一
第二个条件 连续3天下单的用户ID 这个是一对一的记录 一行一条记录 是一个用户对应这三天的下单天数总计 我称之为一对一
第一种呈现方式:我想呈现的是这样的一个表包含下面一个字段
一个用户,下单天数,三天每一天的金额(符合单笔订单AB和>=68,因此需要一个最细的明细 一个订单具体到每个产品去的原始明细 这样看起来比较清晰 这个展现的过程是把单笔订单满足条件的用户先筛选出来 然后再去判断他的下单天数
a3表having 已经对用户ID 进行了单笔订单满足条件的控制 然后下面就是计算下单天数 因为一天可能会出现多个订单 所以需要再进行一次对用户 和 订单日期的Group by
最后计算count(订单日期) 天数 按照天数降序 以group by 用户 结束 把用户中符合单笔条件的下单天数计算出来 再去判断就可以把用户找出来
这样表的结果也是一对一 一个用户一行记录
SELECT 城市,用户ID,用户名称,SUM(金额) AS 3天总金额,COUNT(订单日期) AS 下单天数,SUM(IF(订单日期='2016-11-08',AB金额和,NULL)) AS 8日AB金额和,SUM(IF(订单日期='2016-11-09',AB金额和,NULL)) AS 9日AB金额和,SUM(IF(订单日期='2016-11-10',AB金额和,NULL)) AS 10日AB金额和
FROM (
SELECT 城市,用户ID,用户名称,订单日期,SUM(金额) AS 金额,SUM(AB金额和) AS AB金额和,SUM(A金额) AS A金额,SUM(B金额) AS B金额
FROM (
SELECT 城市,用户ID,用户名称,订单日期,订单ID,SUM(金额) AS 金额,(SUM(IF(产品分类="A",金额,0))+SUM(IF(产品分类="B",金额,0))) AS AB金额和,SUM(IF(产品分类="A",金额,NULL)) AS A金额 ,SUM(IF(产品分类="B",金额,NULL)) AS B金额
FROM(
SELECT 城市,用户ID,用户名称,DATE(订单日期) AS 订单日期,`订单ID`,a1.`产品ID`,a1.`产品名称`,`产品分类`,`金额`
FROM `a003_order` AS a1
LEFT JOIN `a002_sku` AS a2 ON a1.产品ID=a2.产品ID
WHERE 城市='济南' AND 订单日期>="2016-11-08" AND 订单日期<"2016-11-11" AND 金额>0
) AS a3
GROUP BY 订单ID
HAVING (SUM(IF(产品分类="A",金额,0))+SUM(IF(产品分类="B",金额,0)))>=68
ORDER BY 用户ID
) AS a
GROUP BY 用户ID,订单日期
) AS b
GROUP BY 用户ID
ORDER BY COUNT(订单日期) DESC
第二种呈现方式:我先把所有用户在这3天中的汇总情况计算出来,一个用户一行记录,下单天数,下定单总数,3天A的总额,B的总额,AB总额和,这个是主表
最后再去判断这些用户 哪些是单笔订单满足68的的用户 当做从表 left join 主表 以用户相同为条件
这两个表都是一对一的表 都从用户为角度出发
SELECT a.*,b.标识
FROM (#以用户ID汇总 一对一 3天内所有下单的用户
SELECT 城市,用户ID,COUNT(订单日期) AS 下单天数,SUM(订单数) AS 订单数,SUM(AB金额和) AS AB金额和,SUM(A金额) AS A金额,SUM(B金额) AS B金额
FROM (
SELECT 城市,用户ID,订单日期,COUNT(订单ID) AS 订单数,SUM(AB金额和) AS AB金额和,SUM(A金额) AS A金额,SUM(B金额) AS B金额
FROM (
SELECT 城市,用户ID,DATE(订单日期) AS 订单日期,订单ID,SUM(金额) AS 订单总额
,(SUM(IF(a2.产品分类="A",金额,0))+SUM(IF(a2.产品分类="B",金额,0))) AS AB金额和
,SUM(IF(a2.产品分类="A",金额,NULL)) AS A金额
,SUM(IF(a2.产品分类="B",金额,NULL)) AS B金额
FROM `a003_order` AS a1
LEFT JOIN `a002_产品` AS a2 ON a1.产品ID=a2.产品ID
WHERE 城市='济南' AND 订单日期>="2016-11-08" AND 订单日期<"2016-11-11" AND 金额>0 AND 用户ID=44825
GROUP BY 订单ID
) AS a3
GROUP BY 用户ID,订单日期
) AS a4
GROUP BY 用户ID
) AS a
LEFT JOIN (#取出AB和单笔订单>=68的用户订单 一对一
SELECT b3.*
FROM (#订单ID明细 一个用户对应多个订单ID 一对多
SELECT 城市,用户ID,DATE(订单日期) AS 订单日期,订单ID,SUM(金额) AS 订单总额
,(SUM(IF(b2.产品分类="A",金额,0))+SUM(IF(b2.产品分类="B",金额,0))) AS AB金额和
,SUM(IF(b2.产品分类="A",金额,NULL)) AS A金额
,SUM(IF(b2.产品分类="B",金额,NULL)) AS B金额
,CASE WHEN (SUM(IF(b2.产品分类="A",金额,0))+SUM(IF(b2.产品分类="B",金额,0)))>=68 THEN "3天内有单笔订单>=68" ELSE NULL END AS 标识
FROM `a003_order` AS b1
LEFT JOIN `a002_产品` AS b2 ON b1.产品ID=b2.产品ID
WHERE 城市='济南' AND 订单日期>="2016-11-08" AND 订单日期<"2016-11-11" AND 金额>0 AND 用户ID=44825
GROUP BY 订单ID
ORDER BY (SUM(IF(b2.产品分类="A",金额,0))+SUM(IF(b2.产品分类="B",金额,0))) DESC
) AS b3
WHERE 标识 IS NOT NULL
GROUP BY 用户ID
) AS b ON a.用户ID=b.用户ID
MySQL多个条件以什么表当做主条件表_20161111周五的更多相关文章
- SQL学习:主键,外键,主键表,外键表,数据库的表与表之间的关系;
在数据库的学习中,对于一个表的主键和外键的认识是非常重要的. 主键:在一个表中,能唯一的表示一个事物(或者一条记录)的字段,我们称之为主键 注意: 主键的设置可以不只是用一个字段,也可以用若干个字段的 ...
- 三十一.MySQL存储引擎 、 数据导入导出 管理表记录 匹配条件
1.MySQL存储引擎的配置 查看服务支持的存储引擎 查看默认存储类型 更改表的存储引擎 设置数据库服务默认使用的存储引擎 1.1 查看存储引擎信息 mysql> SHOW ENGINES\G ...
- MySQL表的创建和表中数据操作
这篇文章主要介绍在navicat的命令界面操作mysql.主要涉及建立表结构,和对表中数据的增加删除修改查询等动作.站在一个新手角度的简单mysql表结构和数据操作. ☆ 准备工作 1,保证自己的电脑 ...
- mysql复制表数据或表结构到新表中
MySQL复制表数据到新表的几个步骤. 1.MySQL复制表结构及数据到新表 CREATE TABLE new_table SELECT * FROM old_table; 2.只复制表结构到新表 C ...
- mysql 从5.1升级到5.5.33 后 innodb 表出错 及 innodb表修复
服务器使用的是mysql 5.1,了解到 5.5 系列的版本 innodb 的性能有很大提升,就想升级下.按照查到的步骤: http://www.myhack58.com/Article/sort09 ...
- MySQL 复制表到另一个表
1.复制表结构及数据到新表 create table 新表 select * from 旧表 2.只复制表结构到新表 方法1:(低版本的mysql不支持,mysql4.0.25 不支持,mysql5已 ...
- MySQL之单表查询 一 单表查询的语法 二 关键字的执行优先级(重点) 三 简单查询 四 WHERE约束 五 分组查询:GROUP BY 六 HAVING过滤 七 查询排序:ORDER BY 八 限制查询的记录数:LIMIT 九 使用正则表达式查询
MySQL之单表查询 阅读目录 一 单表查询的语法 二 关键字的执行优先级(重点) 三 简单查询 四 WHERE约束 五 分组查询:GROUP BY 六 HAVING过滤 七 查询排序:ORDER B ...
- MySQL用sql复制表数据到新表的方法
用sqlyog无法直接复制出一个不同表名的表来,只能copy到其他库上同名的表. 在MySQL数据库中,应该如何用sql将表数据复制到新表中呢? 本人通过试验测试成功了,而且相当简单易懂,速度也非常快 ...
- MySQL中不允许使用列别名作为查询条件
在MySQL中有个特殊的规定,即不允许使用列别名作为查询条件.比如有下面一个表: select ID, title, concept, conceptLength, ...
随机推荐
- Fragment小结
Fragment是Android3.0之后增加的新特性,通常人们叫它碎片.可是,我认为把它理解成一个View模块比較好,尽管它不是继承自View.假设阅读过源代码就知道它是内置View对象从而实现Vi ...
- 一文了解@Conditional注解说明和使用
@Conditional:Spring4.0 介绍了一个新的注解@Conditional,它的逻辑语义可以作为"If-then-else-"来对bean的注册起作用. @Con ...
- CSS3 实现背景透明,文字不透明,兼容所有浏览器
<!DOCTYPE html><html><head><meta charset="utf-8"><title>opac ...
- 小练习:用socket实现Linux和Windows之间的通信
在日常生活中,绝大部分人使用的机器通常是windows系统,可是对于研发人员,开发.编译等工作往往是建立在linux机器上.其实.在服务器方面,Linux.UNIX和WindowsServer占领了市 ...
- 对于一个字符串,请设计一个高效算法,找到第一次重复出现的字符。 给定一个字符串(不一定全为字母)A及它的长度n。请返回第一个重复出现的字符。保证字符串中有重复字符,字符串的长度小于等于500。
// 第一种方法 // ConsoleApplication10.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include < ...
- Unable to save settings: Failed to save settings. Please restart PyCharm解决
将工程的.ideas目录删掉,重启pycharm即可.
- erlang的token值加解密
对于加解密,需客户端和服务器制定好对应的规则(如:加密算法(aes,des等).加密模式(cbc,cfb)),去加密,再按逆序列解密.这里的key是根据数字.大小写字母.符合组合的,每次请求获取一个动 ...
- 从symbol link和hard link 到 unlink函数的一点记录
之前一直对Linux的文件类型中的 “l” 类型的了解不是很深入,最近经过“圣经”指点,略知一二,在此先记录一下,以便以后查阅,之后会对文件和目录.文件I/O这部分再扩充. 首先需明确,Unix在查阅 ...
- EasyPlayer RTSP播放器对RTSP播放地址url的通用兼容修改意见
问题反馈 最近在线上遇到一位老朋友咨询关于EasyPlayer播放器的事情,大概现象就是分别用EasyPlayer和vlc播放大华摄像机的RTSP流,流地址是:rtsp://admin:admin12 ...
- [转]Struts form传值
Struts form传值 大约三四个月没用过struts框架,突然想拾起来,却发现好多都忘了.出现传值传不过来的问题.没办法,上网查了一下,看见了一位老师的帖子,总结的很好.特此转载与分享,文末附链 ...