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 ...
随机推荐
- BZOJ 1293 SCOI2009 生日礼物 堆
题目大意:给定一个数轴上n个点,每一个点有一种颜色,一共k种颜色.求一个最短的区间,包括全部k种颜色 卡了一段时间0.0 一開始想二分答案啥的 后来发现数据范围太大写不了0.0 后来去找题解才发现尼玛 ...
- 19:ReverseNumber数字颠倒
题目描述 描述:输入一个整数,将这个整数以字符串的形式逆序输出 程序不考虑负数的情况,若数字含有0,则逆序形式也含有0,如输入为100,则输出为001 输入描述:输入一个int整数 输出描述:将这个整 ...
- LVS-DR,real-server为windows 2008的配置
LVS-DR,real-server为windows 2008的配置 部署邮件系统负载均衡,采用LVS-DR模式,调度器是一台centos 5.8,real-server是两台windows2008, ...
- UML类图简明教程
作者:郭孝星 微博:郭孝星的新浪微博 邮箱:allenwells@163.com 博客:http://blog.csdn.net/allenwells Github:https://github.co ...
- 【设计模式】C++单例模式的几种写法——Java自动加载内部类对象,C++怎么破?
单例模式是最简单的设计模式,就让我像玩简单的游戏一样写下去吧. v1: 简单模式 和这个版本有过一面之缘,但不敢苟同. class Singleton { private: Singleton() { ...
- PHP中输出文件,怎么区别什么时候该用readfile() , fread(), file_get_contents(), fgets()
我在服务器端(Apache环境)上放了一个安卓apk安装包的下载链接,使用readfile()读取apk文件输出下载后,手机安装apk显示解析包错误.但apk本身没问题,下载后文件的大小也是完整的.服 ...
- AWR元数据的迁移或导入到其它数据库
我们能够将AWR元数据迁移(导入)到其它数据库.低版本号的导入到高版本号,再用高版本号的数据库生成AWR报告,也能使用一些新特性,如 SQL ordered by Physical Reads (Un ...
- Linux的经常使用命令(1) - 指定执行级别
命令:init [0123456] 执行级别 0:关机 1:单用户 2:多用户状态没有网络服务 3:多用户状态有网络服务 4:系统未使用保留给用户 5:图形界面 6:系统重新启动 经常使用执行级别是3 ...
- BTC、BCH和BSV三者到底有什么区别?
比特币发展到今天已经有10个年头了,在这十年的发展中,比特币一共经历了两次重要的分裂,现在变成了三种货币,第一种是目前继承了比特币绝大多数遗产的BTC:第二种是BCH:第三种是BSV.那这三种货币到底 ...
- 可视化工具与pymongo
可视化工具 链接:https://robomongo.org/ pymongo 官网:http://api.mongodb.com/python/current/tutorial.html from ...