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
时间: 2024-10-22 14:05:19

MySQL多个条件以什么表当做主条件表_20161111周五的相关文章

三十一.MySQL存储引擎 、 数据导入导出 管理表记录 匹配条件

1.MySQL存储引擎的配置 查看服务支持的存储引擎 查看默认存储类型 更改表的存储引擎 设置数据库服务默认使用的存储引擎 1.1 查看存储引擎信息 mysql> SHOW ENGINES\G 1.2 查看默认存储类型 mysql> SHOW VARIABLES LIKE 'default_storage_engine'; +------------------------+--------+ | Variable_name          | Value  | +-------------

MySQL表的创建和表中数据操作

这篇文章主要介绍在navicat的命令界面操作mysql.主要涉及建立表结构,和对表中数据的增加删除修改查询等动作.站在一个新手角度的简单mysql表结构和数据操作. ☆ 准备工作 1,保证自己的电脑安装了mysql(my.ini下的字符集设置是utf8) 2,确保电脑同时安装navicat(任意版本) 3,保证mysql服务器已经启动 注:若对navicat操作不熟,请参照<<navicat从下载到使用>>这篇文章. ☆ 打开控制台 在navicat的tools(工具)菜单栏选择

Linux命令:MySQL系列之五--SELECT单表查询、多表查询升级及删除,插入

SELECT:查询 SELECT select-list FROM tb WHERE qualification  根据标准qualification查找对应的行 查询语句类型:  qualification条件  field领域  distinct独特的 简单查询: 多表查询: 子查询: SELECT * FROM tb_name: 查询tb_name表的所有信息 SELECT field1,field2 FROM tb_name: 投影显示所设定的领域条目(field),一个field就是一

★★JSP+Struts+Mysql构建的MVC三层框架对一张数据表的CURD

项目实现流程 大体流程:搭建环境 à 开发后台 à 开发前台 建立工程(struts2CURD),拷贝jar包,建立struts.xml文件,搭建环境 建立数据库和数据源配置:dbcpconfig.properties 建立db.sql:里面全是数据库操作的一些语句 建立操作数据库的工具:*.util:DBCPUtil.java,用于加载数据源.getDataSource(); *.Domain:User.java 继承ActionSupport,实现Serializable接口. ????写好

MySQL中不允许使用列别名作为查询条件

在MySQL中有个特殊的规定,即不允许使用列别名作为查询条件.比如有下面一个表: select     ID,     title,     concept,     conceptLength,     addUserId,     modifyTimefrom collections_wisdom 将SQL修改如下: select     ID+1 as newID,     title,     concept,     conceptLength,     addUserId,    

Mysql DBA 高级运维学习笔记-DML之修改表中的数据实战

9.10 修改表中的数据 9.10.1 修改表中指定条件固定列的数据 1.命令语法:update 表名 set 字段=新值,-.where 条件(一定要注意条件) 2.修改指定的行字段的内容 a.查看要修改的表 [email protected] 02:3907->select * from test; +----+-----------+ | id | name | +----+-----------+ | 1 | wwnwan| | 2 | zbf | | 3 | lisi | | 4 |

MySQL数据库:SQL语句基础、库操作、表操作、数据类型、约束条件、表之间的关系

数据库相关概念: 1. 数据库服务器:运行数据库管理软件的计算机 2. 数据库管理软件:MySQL.Oracle.db2.slqserver 3. 库:文件夹,用来组织文件/表 4. 表:文件(类似于excel),用来存放多行内容/多条记录 5. 记录:事物一系列典型的特征 6. 数据:描述事物特征的符号 MySQL数据库就是一个套接字软件,用来管理其他机器上的数据文件 MySQL介绍: MySQL是一个关系型数据库管理系统:就是一个基于socket编写的C/S架构胡软件 客户端软件 mysql

MySQL 复制表到另一个表

1.复制表结构及数据到新表 create table 新表 select * from 旧表 2.只复制表结构到新表 方法1:(低版本的mysql不支持,mysql4.0.25 不支持,mysql5已经支持了) create table 新表 like 旧表 方法2: create table 新表 select * from 旧表 limit 0 方法3: create table 新表 select * from 旧表 where 不成立条件 3.复制旧表的数据到新表 1.(假设两个表结构一

MySQL数据库 多表查询 交叉连接 自然连接 内连接 自连接 外连接 子查询 多表查询练习 单表查询练习 &#109806;

原文: http://blog.gqylpy.com/gqy/466 置顶:来自一名75后老程序员的武林秘籍--必读(博主推荐) 来,先呈上武林秘籍链接:http://blog.gqylpy.com/gqy/401/ 你好,我是一名极客!一个 75 后的老工程师! 我将花两分钟,表述清楚我让你读这段文字的目的! 如果你看过武侠小说,你可以把这个经历理解为,你失足落入一个山洞遇到了一位垂暮的老者!而这位老者打算传你一套武功秘籍! 没错,我就是这个老者! 干研发 20 多年了!我也年轻过,奋斗过!我