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,并以超链接形式标明文章原始出处,否则将 ...
随机推荐
- 【java】之joda-time的使用
Joda-Time Home:http://joda-time.sourceforge.net/ JavaDoc:http://joda-time.sourceforge.net/apidocs/in ...
- 【MySQL】锁问题最佳实践
最近一段时间处理了较多锁的问题,包括锁等待导致业务连接堆积或超时,死锁导致业务失败等,这类问题对业务可能会造成严重的影响,没有处理经验的用户往往无从下手.下面将从整个数据库设计,开发,运维阶段介绍如何 ...
- 备份触发器:ADDC3
CREATE OR REPLACE TRIGGER "XMV502"."ADDC3" before insert on bd_cubasdoc for each ...
- js声明json数据,打印json数据,遍历json数据
1.js声明json数据: 2.打印json数据: 3.遍历json数据 //声明JSON var json = {}; json.a = 1; //第一种赋值方式(仿对象型) json['b'] = ...
- AMap地图加载完成事件
<!doctype html> <html> <head> <meta charset="utf-8"> <meta http ...
- 常用SQL语句
一.基础 1.说明:创建数据库 CREATE DATABASE database-name 2.说明:删除数据库 drop database dbname 3.说明:备份sql server --- ...
- Windows下python virtualenv使用,镜像源设置,批量安装,安装scipy,numpy
镜像源设置 在C:\Users\Administrator\下建立pip文件夹,然后在里面创建了一个pip.ini 内容为: [global]index-url = https://pypi.tuna ...
- [CF442A] Borya and Hanabi (暴力bitmask)
题目链接:http://codeforces.com/problemset/problem/442/A 题目大意:给你n张卡片,你知道这n张卡片都是什么,但是不知道他们的位置.你每次可以请求朋友指出一 ...
- XE6 & IOS开发之开发者账号、苹果证书(3):关于在XE6中使用苹果证书的简单介绍
网上能找到的关于Delphi XE系列的移动开发的相关文章甚少,本文尽量以详细的图文内容.傻瓜式的表达来告诉你想要的答案. 原创作品,请尊重作者劳动成果,转载请注明出处!!! 1.关于在XE6中使用苹 ...
- the import javax.servlet
问题: 在eclipse中编写servlet时出现“the import javax.servlet unresolved” 问题原因: 缺少servlet-api.jar架包. 问题解决办法: 在e ...