MySQL_订单类型细分_20161222
#目前在做一个各城市日订单角度的对比分析,因此需要对订单类型进行一下规整。由于App上产品活动许多,查询了多个表,将订单类型规则进行了统一,优惠券和满减券不能同时使用,创建的这两个表都是以订单ID为key,赠品在毛利表中销售额为0且成本额>0
但是赠品和优惠券使用会有交叉,因此没法和优惠券、满减券进行纵向合并
#订单ID 14天明细
SELECT a1.*
,CASE WHEN a2.优惠券ID IS NULL THEN '正常订单' ELSE a2.优惠类 END AS 是否正常订单
,CASE WHEN a2.优惠券ID IS NULL THEN '正常订单' WHEN a2.优惠类='专项活动'THEN '专项活动' ELSE '其他优惠券' END AS 专题
,a2.使用时间,a2.优惠券ID,a2.优惠券名称,a2.优惠额
,CASE WHEN a1.订单日期=a2.使用时间 THEN '当天' ELSE '非当天' END AS 即时情况
,CASE WHEN a3.订单ID IS NULL THEN '无' ELSE '有' END AS 是否有赠品,a3.赠品额
FROM (
SELECT 城市,用户ID,用户名称,DATE(订单日期) AS 订单日期,订单ID,销售员,SUM(金额) AS 金额
,CASE WHEN SUM(金额)>=4000 THEN '【4000元以上】' WHEN SUM(金额)>=3000 THEN '【3000元以上】' WHEN SUM(金额)>=2000 THEN '【2000元以上】' WHEN SUM(金额)>=1000 THEN '【1000元以上】' WHEN SUM(金额)>=500 THEN '【5000元以上】' ELSE '【500元以下】' END AS 金额区间
FROM `a003_order`
WHERE 金额>0 AND 订单日期>=DATE_ADD(CURRENT_DATE,INTERVAL -14 DAY) AND 订单日期<CURRENT_DATE #AND 城市='北京'
GROUP BY 订单ID
) AS a1
LEFT JOIN (#优惠券满减合并
(#优惠券
SELECT a.*
FROM (
SELECT 城市,DATE(使用时间) AS 使用时间,用户ID,订单号 AS 订单ID,SUM(优惠券金额) AS 优惠额,`优惠券ID`,`优惠券名称`,`优惠券类别`
,CASE WHEN (优惠券类别='兑换优惠劵(赠优惠劵)' OR 优惠券类别='客服专用券' OR 优惠券类别='满赠优惠券(赠优惠券)') AND 优惠券名称 LIKE '%无门槛%' THEN '全品类可用'
WHEN 优惠券类别='注册优惠券' AND 优惠券名称 LIKE '%注册%无门槛%' THEN '全品类可用'
WHEN 优惠券类别='兑换优惠劵(赠优惠劵)' AND 优惠券名称 LIKE '%超值兑换券%' THEN '专项活动' ELSE 优惠券类别 END AS 优惠类
FROM `a016_order_customercoupon_xref`
WHERE 使用时间>=DATE_ADD(CURRENT_DATE,INTERVAL -14 DAY) AND 使用时间<CURRENT_DATE
GROUP BY 订单号
ORDER BY 城市,DATE(使用时间),SUM(优惠券金额) DESC
) AS a
ORDER BY 城市,使用时间,优惠券名称)
UNION ALL (#满减
SELECT b.*
FROM (#满减券的ID 不同品类一个订单可以使用多个ID
SELECT 城市,DATE(下单时间) AS 使用时间,用户ID,订单ID,SUM(满减金额) AS 优惠额,`活动ID` AS 优惠券ID,活动描述 AS 优惠券名称,'满减' AS 优惠券类别,'满减' AS 优惠类
FROM `a036_order_promotion_xref`
WHERE 下单时间>=DATE_ADD(CURRENT_DATE,INTERVAL -14 DAY) AND 下单时间<CURRENT_DATE
GROUP BY 订单ID
) AS b
ORDER BY 城市,使用时间,优惠券名称
)
) AS a2 ON a1.订单ID=a2.订单ID
LEFT JOIN (#05赠品包含后台满赠模块 包含买一赠一 满赠活动 SKUID in (866040,878976) 退包装物的订单 也包含在赠品中了
SELECT 城市,用户ID,订单号 AS 订单ID,SUM(成本额) AS 赠品额
FROM `a005_account`
WHERE 销售额=0 AND 成本额>0 AND 订单日期>=DATE_ADD(CURRENT_DATE,INTERVAL -14 DAY) AND 订单日期<CURRENT_DATE AND 类型<>'退货'
GROUP BY 订单号
) AS a3 ON a1.订单ID=a3.订单ID
ORDER BY 城市,用户ID,订单ID,金额 DESC
MySQL_订单类型细分_20161222的更多相关文章
- 112_Power Pivot 销售订单按 sku 订单类型特殊分类及占比相关
博客:www.jiaopengzi.com 焦棚子的文章目录 请点击下载附件 一.背景 经过了一个双十一后,天天面对的都是订单.于是有了关于销售订单按sku类型分类的需求. 说明:(暂且不讨论这样分类 ...
- mysql按月统计六个月内不同类型订单的成交金额
mysql按月统计六个月内不同类型订单的成交金额 创建数据库 CREATE DATABASE test; 创建订单表 CREATE TABLE `t_order` ( `id` ) NOT NULL ...
- 【SAP业务模式】之ICS(六):发票输出类型
这篇开始主要讲述发票输出类型: 首先我们新建一个发票类型,用于公司间的发票MIV,而标准的发票类型还是F2保持不变: 一.新建发票类型: 目录:SPRO-销售与分销-出具发票-开票凭证-定义出具发票类 ...
- SAP 订单状态跟踪
*&--------------------------------------------------------------------- *& Program name: *& ...
- ABAP 订单转交货单
*& Report ZSDR025 *& *&---------------------------------------------------------------- ...
- SAP公司间采购订单关联交货单报表源代码(自己收藏)
SPAN { font-family: "Courier New"; font-size: 10pt; color: #000000; background: #FFFFFF } ...
- PP生产订单创建、下达、报工、收货、投料
转自http://blog.sina.com.cn/s/blog_69fb8eb60102vpjd.html SAP 物料订单创建.下达.报工.收货与投料(ABAP代码) (2015-06-03 22 ...
- 调用SAP函数创建寄售退货订单的时候报错:业务对象 BUS2032 是销售订单,销售凭证类别 H 是退货。
RE.KR订单类型用BAPI_CUSTOMERRETURN_CREATE 其他用BAPI_SALESORDER_CREATEFROMDAT2
- [SAP ABAP开发技术总结]SD销售订单定价过程
声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...
随机推荐
- 一款好用且免费的语句分析工具Plan Explorer
在调优过程中的查询语句优化阶段,分析语句的执行计划是必经之路,一款好的执行计划分析工具确实可以帮助我们事半功倍 小贴士:Plan Explorer是将Plan Explorer 专业版与免费版整合在一 ...
- linux下tomcat的安装和配置
安装前要求: 1. 安装java环境. 2. 配置java环境变量 开始了: 1. 在官网下载tomcat:http://tomcat.apache.org/ 2. linux环境选择.zip或者.t ...
- Android学习笔记(十)
Android控件——ListView ListView允许用户通过手指上下滑动的方式将屏幕外的数据滚动到屏幕内,同时 屏幕上原有的数据则会滚动出屏幕. 1.ListView的简单用法 新建一个Lis ...
- C#开发分享:如何改变系统鼠标样式
开发过程中发现需要用到改变鼠标样式(就是光标的样子),但是在网上找了很多资料,都是介绍在程序中使用,我需要的效果时在系统级使用.现在找到了,分享给大家. [DllImport("user32 ...
- korn shell
"$*" is a single string that consists of all of the positional parameters "$@" ...
- 如何在Delphi里面查看程序的汇编代码?
开发工具:Delphi 10 Update2 1,在源代码中设置至少一个断点,目的让我们进入调试模式. 2,启动调试,当程序进入调试模式,停留在我们设定的断点处时候,使用快捷键"CTRL+A ...
- 如何消除移动端a标签点击时的蓝色底色以及a标签link、visited、hover、active的顺序
1.消除a标签移动端点击时的蓝色底色 -webkit-tap-highlight-color:transparent 2.link.visited.hover.active的顺序 a:link{tex ...
- iOS开发之CocoaPods的使用
你开发iOS的方式还是石器时代吗?在这个世界上并不是所有的软件开发人员都是码农.在这个世界上有很多的geek存在他们为这个语言的发展做出了很大的贡献.现在随着iOS开发者的曾多也就出现了iOS程序猿提 ...
- Sublime Text
今天在网上找了个Sublime Text 3 Build 3065 的 license key .在最新的Build 3083 下可以使用,记录下. ----- BEGIN LICENSE ----- ...
- MySql绿色版下载,安装,配置详解
下载完成之后解压,楼主用的版本是:mysql-5.7.15-winx64 解压完在根目录下建立一个data文件夹和my-default.ini my-default.ini里面的内容如下:(红色内容根 ...