#目前在做一个各城市日订单角度的对比分析,因此需要对订单类型进行一下规整。由于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的更多相关文章

  1. 112_Power Pivot 销售订单按 sku 订单类型特殊分类及占比相关

    博客:www.jiaopengzi.com 焦棚子的文章目录 请点击下载附件 一.背景 经过了一个双十一后,天天面对的都是订单.于是有了关于销售订单按sku类型分类的需求. 说明:(暂且不讨论这样分类 ...

  2. mysql按月统计六个月内不同类型订单的成交金额

    mysql按月统计六个月内不同类型订单的成交金额 创建数据库 CREATE DATABASE test; 创建订单表 CREATE TABLE `t_order` ( `id` ) NOT NULL ...

  3. 【SAP业务模式】之ICS(六):发票输出类型

    这篇开始主要讲述发票输出类型: 首先我们新建一个发票类型,用于公司间的发票MIV,而标准的发票类型还是F2保持不变: 一.新建发票类型: 目录:SPRO-销售与分销-出具发票-开票凭证-定义出具发票类 ...

  4. SAP 订单状态跟踪

    *&--------------------------------------------------------------------- *& Program name:  *& ...

  5. ABAP 订单转交货单

    *& Report  ZSDR025 *& *&---------------------------------------------------------------- ...

  6. SAP公司间采购订单关联交货单报表源代码(自己收藏)

    SPAN { font-family: "Courier New"; font-size: 10pt; color: #000000; background: #FFFFFF } ...

  7. PP生产订单创建、下达、报工、收货、投料

    转自http://blog.sina.com.cn/s/blog_69fb8eb60102vpjd.html SAP 物料订单创建.下达.报工.收货与投料(ABAP代码) (2015-06-03 22 ...

  8. 调用SAP函数创建寄售退货订单的时候报错:业务对象 BUS2032 是销售订单,销售凭证类别 H 是退货。

    RE.KR订单类型用BAPI_CUSTOMERRETURN_CREATE 其他用BAPI_SALESORDER_CREATEFROMDAT2

  9. [SAP ABAP开发技术总结]SD销售订单定价过程

    声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...

随机推荐

  1. 【java】之joda-time的使用

    Joda-Time Home:http://joda-time.sourceforge.net/ JavaDoc:http://joda-time.sourceforge.net/apidocs/in ...

  2. 【MySQL】锁问题最佳实践

    最近一段时间处理了较多锁的问题,包括锁等待导致业务连接堆积或超时,死锁导致业务失败等,这类问题对业务可能会造成严重的影响,没有处理经验的用户往往无从下手.下面将从整个数据库设计,开发,运维阶段介绍如何 ...

  3. 备份触发器:ADDC3

    CREATE OR REPLACE TRIGGER "XMV502"."ADDC3" before insert on bd_cubasdoc for each ...

  4. js声明json数据,打印json数据,遍历json数据

    1.js声明json数据: 2.打印json数据: 3.遍历json数据 //声明JSON var json = {}; json.a = 1; //第一种赋值方式(仿对象型) json['b'] = ...

  5. AMap地图加载完成事件

    <!doctype html> <html> <head> <meta charset="utf-8"> <meta http ...

  6. 常用SQL语句

    一.基础 1.说明:创建数据库 CREATE DATABASE database-name 2.说明:删除数据库 drop database dbname 3.说明:备份sql server --- ...

  7. Windows下python virtualenv使用,镜像源设置,批量安装,安装scipy,numpy

    镜像源设置 在C:\Users\Administrator\下建立pip文件夹,然后在里面创建了一个pip.ini 内容为: [global]index-url = https://pypi.tuna ...

  8. [CF442A] Borya and Hanabi (暴力bitmask)

    题目链接:http://codeforces.com/problemset/problem/442/A 题目大意:给你n张卡片,你知道这n张卡片都是什么,但是不知道他们的位置.你每次可以请求朋友指出一 ...

  9. XE6 & IOS开发之开发者账号、苹果证书(3):关于在XE6中使用苹果证书的简单介绍

    网上能找到的关于Delphi XE系列的移动开发的相关文章甚少,本文尽量以详细的图文内容.傻瓜式的表达来告诉你想要的答案. 原创作品,请尊重作者劳动成果,转载请注明出处!!! 1.关于在XE6中使用苹 ...

  10. the import javax.servlet

    问题: 在eclipse中编写servlet时出现“the import javax.servlet unresolved” 问题原因: 缺少servlet-api.jar架包. 问题解决办法: 在e ...