MySQL 单笔订单满6个及以上产品且金额>=300赠送优惠券_20161103
活动内容: 单笔订单满6个及以上产品(帽子、浴巾除外),金额满赠300元,即赠送300-10元(除帽子、浴巾外)优惠券一张。
需求数据:满足条件的用户ID
活动时间:11.2-11.5(4天)
活动规则:
① 使用无忧券ID908-913的商户即便满足条件也不参与此次活动
② 参与秒杀、满赠的活动的商户可以参与此次活动
③ 11.2日、3日数据4日下午发放;11、4日、5日订单7日发放
1.我们可以给他一个最细的明细,每个订单每个产品下单的情况
SELECT a1.城市,a1.用户ID,b.用户名称,b.用户地址,b.联系电话,DATE(订单日期) AS 订单日期,a1.订单ID,a1.销售员,a1.产品ID,a1.产品名称,SUM(a1.金额) AS 金额
FROM `a003_order` AS a1
LEFT JOIN `a001_resterant` AS b ON a1.用户ID=b.用户ID
WHERE a1.城市='济南' AND a1.订单日期>="2016-11-02" AND a1.订单日期<"2016-11-06" AND a1.金额>0 AND (a1.产品名称 NOT LIKE "%帽子%" OR a1.产品名称 NOT LIKe"%浴巾%" )
GROUP BY a1.订单ID,a1.产品ID
2、给他一个订单汇总,其中订单后在跟随使用优惠券的情况
SELECT a2.城市,a2.用户ID,a2.用户名称,a2.用户地址,a2.联系电话,a2.订单日期,a2.订单ID,a2.销售员,COUNT(a2.产品ID) AS 产品数,SUM(a2.金额) AS 订单额,
CASE WHEN COUNT(a2.产品ID)>=6 AND SUM(a2.金额)>=300 THEN "产品数>=6&单笔订单大于300" ELSE NULL END AS 标识,a4.优惠券ID,a4.优惠券名称,a4.优惠券金额
FROM (
SELECT a1.城市,a1.用户ID,b.用户名称,b.用户地址,b.联系电话,DATE(订单日期) AS 订单日期,a1.订单ID,a1.销售员,a1.产品ID,a1.产品名称,SUM(a1.金额) AS 金额
FROM `a003_order` AS a1
LEFT JOIN `a001_resterant` AS b ON a1.用户ID=b.用户ID
WHERE a1.城市='济南' AND a1.订单日期>="2016-11-02" AND a1.订单日期<"2016-11-06" AND a1.金额>0 AND (a1.产品名称 NOT LIKE "%帽子%" OR a1.产品名称 NOT LIKE
"%浴巾%" )
GROUP BY a1.订单ID,a1.产品ID
) AS a2
LEFT JOIN (#未使用优惠券ID 908到913的用户订单
SELECT a3.用户ID,a3.订单号,a3.优惠券ID,a3.优惠券名称,SUM(优惠券金额) AS 优惠券金额
FROM `a016_order_customercoupon_xref` AS a3
WHERE a3.城市="济南" AND a3.使用时间>="2016-11-02" AND a3.使用时间<"2016-11-06" AND (a3.优惠券ID<908 OR a3.优惠券ID>913)
GROUP BY a3.订单号
) AS a4 ON a4.订单号=a2.订单ID
GROUP BY a2.订单ID
3、最后对达标的餐馆再进行汇总group by having 条件筛选单笔订单符合条件的
SELECT a.城市,a.用户ID,a.用户名称,a.用户地址,a.联系电话,c.销售员,SUM(a.订单额) AS 4天内订单额,COUNT(a.订单ID) AS 4天内订单数,
CASE WHEN SUM(a.订单额)>=300 THEN "10元(除帽子、浴巾外)优惠券一张" ELSE NULL END AS 赠送优惠券
FROM (
SELECT a2.城市,a2.用户ID,a2.用户名称,a2.用户地址,a2.联系电话,a2.订单日期,a2.订单ID,a2.销售员,COUNT(a2.产品ID) AS 产品数,SUM(a2.金额) AS 订单额,
CASE WHEN COUNT(a2.产品ID)>=6 AND SUM(a2.金额)>=300 THEN "产品数>=6&单笔订单大于300" ELSE NULL END AS 标识,a4.优惠券ID,a4.优惠券名称,a4.优惠券金额
FROM (
SELECT a1.城市,a1.用户ID,b.用户名称,b.用户地址,b.联系电话,DATE(订单日期) AS 订单日期,a1.订单ID,a1.销售员,a1.产品ID,a1.产品名称,SUM(a1.金额) AS 金额
FROM `a003_order` AS a1
LEFT JOIN `a001_resterant` AS b ON a1.用户ID=b.用户ID
WHERE a1.城市='济南' AND a1.订单日期>="2016-11-02" AND a1.订单日期<"2016-11-06" AND a1.金额>0 AND (a1.产品名称 NOT LIKE "%帽子%" OR a1.产品名称 NOT LIKE
"%浴巾%" )
GROUP BY a1.订单ID,a1.产品ID
) AS a2
LEFT JOIN (#未使用优惠券ID 908到913的用户订单
SELECT a3.用户ID,a3.订单号,a3.优惠券ID,a3.优惠券名称,SUM(优惠券金额) AS 优惠券金额
FROM `a016_order_customercoupon_xref` AS a3
WHERE a3.城市="济南" AND a3.使用时间>="2016-11-02" AND a3.使用时间<"2016-11-06" AND (a3.优惠券ID<908 OR a3.优惠券ID>913)
GROUP BY a3.订单号
) AS a4 ON a4.订单号=a2.订单ID
GROUP BY a2.订单ID
HAVING COUNT(a2.产品ID)>=6 AND SUM(a2.金额)>=300
) AS a
LEFT JOIN `a003b_order_item` AS c ON c.用户ID=a.用户ID
GROUP BY a.用户ID
ORDER BY SUM(a.订单额) DESC
这样数据对起来也比较方便 可以很方便的看一个用户是否是满足条件达标
MySQL 单笔订单满6个及以上产品且金额>=300赠送优惠券_20161103的更多相关文章
- MySQL_活动期间单笔订单最高的且满600元 判别是重激活客户还是10月注册客户_20161031
将29号和30号两个需求放到一个表当中 首先都满足在10.29到31号之间单笔订单最高的且满600元 数据结构为一个用户一个订单ID 一行一行的 上面是第一个表 我们当做主表 a 第二个表 我们找注册 ...
- MySQL活动期间订单满600元并且在活动日期之前超过30天没有下过单_20161030
计算 活动期间订单满600元并且在活动日期之前超过30天没有下过单 首先拿到这个需求,首先需要明确活动日期区间 10.29-10.31,其次要取这个时间段内某天订单额最高的那天及订单额,再次需要判断这 ...
- mysql优化---订单查询优化:视图优化+索引创建
订单的表结构采用了垂直分表的策略,将订单相关的不同模块的字段维护在不同表中 在订单处理这个页面,需要查询各种维度, 因此为了方便查询创建了v_sale_order视图(老版本) drop view v ...
- 记一次mysql千万订单汇总查询优化
公司订单系统每日订单量庞大,有很多表数据超千万.公司SQL优化这块做的很不好,可以说是没有做,所以导致查询很慢. 正题 节选某个功能中的一句SQL EXPLAIN 查看执行计划 EXPLAIN + S ...
- mysql优化---订单查询优化(1):视图优化+索引创建
订单的表结构采用了垂直分表的策略,将订单相关的不同模块的字段维护在不同表中 在订单处理这个页面,需要查询各种维度, 因此为了方便查询创建了v_sale_order视图(老版本) drop view v ...
- mysql优化---订单查询优化:异步分页处理
订单分页查询: 老的代码是顺序执行查询数据和计算总记录数,但是如果条件复杂的话(比如关联子表)查询的时间要超过20s种 public static PagedList<Map<String ...
- mysql滑动订单问题
先根据以下代码来创建表MonthlyOrders并导入一定的数据 CREATE TABLE MonthlyOrders( ordermonth DATE, ordernum INT UNSIGNED, ...
- mysql cpu 100% 满 优化方案
解决MySQL CPU占用100%的经验总结 - karl_han的专栏 - CSDN博客 https://blog.csdn.net/karl_han/article/details/5630782 ...
- mysql cpu 100% 满 优化方案 解决MySQL CPU占用100%的经验总结
下面是一些经验 供参考 解决MySQL CPU占用100%的经验总结 - karl_han的专栏 - CSDN博客 https://blog.csdn.net/karl_han/article/det ...
随机推荐
- phpdoctor 安装,配置,生成文档
window 下安装phpdoctor 1 安装php,设置环境变量path ,把php 的安装路径加上,比如php 安装在d:/php5/ 2下载phpdoctor,可以去官网下载 http://p ...
- 卡特兰数-Catalan数
卡特兰数的含义: 说到卡特兰数,就不得不提及卡特兰数序列.卡特兰数序列是一个整数序列.其通项公式是我们从中取出的就叫做第n个卡特兰数数,前几个卡特兰数数是:1, 1, 2, 5, 14, 42, 13 ...
- 【C/C++】高亮C++中函数的重写——函数名相同?参数列表相同?返回值相同?
C++的重载给人留下了非常深刻的影响,原因是重载的条件很值得注意:函数名相同,参数列表不相同的两个函数构成重载函数,而无关乎二者的返回值. 但是C++中的函数重写又是另一码事.标准规定:只要函数名相同 ...
- Kindeditor上传图片回显不出来
原因之一: 图片成功上传但是回显不出来,这个时候,要检查返回的图片地址是否加了http://这个玩意,不然会将原来的头加上图片返回地址.
- hibernate QBC查询
HQL运算符 QBC运算符 含义 = Restrictions.eq() 等于equal <> Restrictions.ne() 不等于not equal > Restrict ...
- 【文献阅读】Stack What-Where Auto-encoders -ICLR-2016
一.Abstract 提出一种新的autoencoder -- SWWAE(stacked what-where auto-encoders),更准确的说是一种 convolutional autoe ...
- mysql分组查询n条记录
当业务逻辑越来越复杂时,这个查询的需求会越来越多,今天写成笔记记录下来,防止再忘记 SELECT * FROM `notice` a where add_time > 1513008000 an ...
- mongo-connector导入数据到Es
要求 基于mongo-connector同步数据,必须要求mongodb为复制集架构,原因是此插件是基于oplog操作记录进行数据同步的:而oplog可以说是Mongodb Replication的纽 ...
- 九度OJ 1034:寻找大富翁 (排序)
时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:5925 解决:2375 题目描述: 浙江桐乡乌镇共有n个人,请找出该镇上的前m个大富翁. 输入: 输入包含多组测试用例. ...
- Python文件编码不可以使用UTF16
1. The complete Python source file should use a single encoding. Embedding of differently encoded da ...