Compare commits

..

31 Commits

Author SHA1 Message Date
7ee70b6253 更新全部线下底稿内容,包括数据处理过程、数据质量评估、分析指标及对应截图 2025-10-24 21:32:44 +08:00
4d8fe3ff52 更新数据质量评估描述,添加斯搏兹结算单截图和对应数据库截图 2025-10-24 11:15:48 +08:00
8c2598f1d9 更新数据质量评估斯搏兹结算表、添加斯搏兹结算表截图 2025-10-24 11:05:59 +08:00
wangxu
42349678d2 Merge branch 'main' of http://1.15.179.94:3000/admin/-- 2025-10-23 22:12:48 +08:00
wangxu
3217134a60 3 2025-10-23 22:12:41 +08:00
852d54d03c 提交线下数据质量评估 2025-10-23 19:59:04 +08:00
aa061fb78e 提交数据处理过程-线下 2025-10-23 19:52:47 +08:00
3097dc12bd 提交分析指标汇总-线下 2025-10-23 19:51:00 +08:00
338cdf1ebe 提交线下零售金额核对截图 2025-10-23 19:45:28 +08:00
b2cf74a23e 提交线下数据处理过程执行截图 2025-10-23 19:38:23 +08:00
wangxu
02fa8f7622 2 2025-10-23 19:25:47 +08:00
wangxu
d315b9e52a 1 2025-10-23 15:49:18 +08:00
wangxu
b1a85f5735 底稿 2025-10-22 14:34:30 +08:00
wangxu
00a51ac679 1 2025-10-08 19:32:05 +08:00
wangxu
bff7559882 1 2025-10-08 15:47:05 +08:00
wangxu
b395436b1e 1 2025-09-26 16:49:09 +08:00
34745d3991 删除线下店铺加盟联营抽样统计 2025-09-24 16:06:37 +08:00
19862dbf4a 添加文件夹及线下店铺统计 2025-09-24 15:58:18 +08:00
6cb53ada93 线下店铺抽样统计(销售表) 2025-09-24 13:25:33 +08:00
5c9320ca38 线下店铺加盟联营抽样统计 2025-09-24 12:59:30 +08:00
wangxu
45b09ffc43 1 2025-09-23 17:06:57 +08:00
bede12aec0 上传审计资料需求清单 2025-09-23 16:40:53 +08:00
1ecd0b508b 删除安装包 2025-09-20 15:36:28 +08:00
532574c836 SQL语句更新 2025-09-20 15:12:59 +08:00
0574e30a52 SQL语句更新 2025-09-19 18:46:09 +08:00
2815f094cf sQL语句更新 2025-09-19 15:17:17 +08:00
445bfc3a95 Merge branch 'main' of http://1.15.179.94:3000/admin/heilan 2025-09-19 15:11:43 +08:00
c3896caaf1 Merge branch 'main' of http://1.15.179.94:3000/admin/heilan
# Conflicts:
#	SQL.sql
2025-09-19 15:10:28 +08:00
wangxu
2b80c0c441 Merge branch 'main' of http://1.15.179.94:3000/admin/-- 2025-09-19 15:10:16 +08:00
wangxu
93fdf41096 报告框架 2025-09-19 15:06:50 +08:00
67a5b0c78b DBeaver安装包 2025-09-19 11:48:00 +08:00
463 changed files with 14130 additions and 96 deletions

423
SQL.sql
View File

@@ -1,32 +1,86 @@
<<<<<<< HEAD
-- 线上店铺年度销售金额、订单数量、退款金额、退款订单数、订单均价 -- 线上店铺年度销售金额、订单数量、退款金额、退款订单数、订单均价
SELECT SELECT
sales.store_name as '店铺名称', s.,
year(sales.order_date) AS '年份', s.,
round(sum(sales.order_settle_amt),2) as '销售金额', ROUND(s.,2) AS '销售金额',
COUNT(sales.platform_order_no) + s.,
SUM(LENGTH(sales.platform_order_no) - LENGTH(REPLACE(sales.platform_order_no, ',', ''))) as '订单数量', r.退,
round(sum(change.special_barcode_amt),2) as '退款金额', r.退,
count(refund.platform_order_no) as '退款订单数', ROUND(s./s.,2) AS '订单均价'
round(sum(sales.order_settle_amt)/count(sales.platform_order_no),2) as '订单均价' FROM(
FROM SELECT
dwd_trade_hkaudit_ecommerce_sale_mt sales store_code AS '店铺编码',
left join dwd_trade_hkaudit_ecommerce_sale_return_mt refund YEAR(order_date) AS '年份',
on sales.platform_order_no = refund.platform_order_no SUM(order_settle_amt) AS '销售金额',
left join dwd_trade_hkaudit_ecommerce_sale_change_mt change -- 针对并单号情况,统计总行数加逗号个数得到总订单数量
on refund.platform_order_no = change.platform_order_no COUNT(platform_order_no) +
WHERE SUM(LENGTH(platform_order_no) - LENGTH(REPLACE(platform_order_no, ',', ''))) AS '订单数量'
sales.order_date >= '2022-01-01 00:00:00' FROM
AND sales.order_date <'2025-07-31 00:00:00' dwd_trade_hkaudit_ecommerce_sale_mt
GROUP BY WHERE
sales.store_name, year(sales.order_date) order_date >= '2022-01-01 00:00:00'
AND order_date <'2025-07-01 00:00:00'
GROUP BY
store_code,YEAR(order_date)
) s --
LEFT JOIN(
SELECT
YEAR(order_date) AS '年份',
store_code AS '店铺编码',
ROUND(SUM(refund.amount)+SUM(change.amount),2) AS '退款金额',
COUNT(refund.platform_order_no) AS '退款订单数'
FROM(
SELECT
-- 将拆分后的单个订单号作为分组和查询的键
single_order_id AS single_order_no,
MIN(store_code) AS store_code,
MIN(order_date) AS order_date
FROM(
SELECT
store_code,
platform_order_no,
order_date,
splitByChar(',', platform_order_no) AS order_id_array
FROM dwd_trade_hkaudit_ecommerce_sale_mt
WHERE
order_date >= '2022-01-01 00:00:00'
AND order_date <'2025-07-01 00:00:00'
)
-- 使用arrayJoin将数组中的每个元素展开为一行
ARRAY JOIN order_id_array AS single_order_id
GROUP BY single_order_no
) sales
LEFT JOIN(
SELECT
platform_order_no,
SUM(return_goods_amt)
FROM
dwd_trade_hkaudit_ecommerce_sale_return_mt
GROUP BY
platform_order_no
) refund
ON sales.platform_order_no = refund.platform_order_no
LEFT JOIN(
SELECT
platform_order_no,
SUM(special_barcode_amt) AS amount
FROM
dwd_trade_hkaudit_ecommerce_sale_change_mt
) change
ON sales.platform_order_no = change.platform_order_no
WHERE
refund.platform_order_no IS NOT NULL
GROUP BY
store_code,YEAR(order_date)
) r -- 退款
ON s. = r. AND s. = r.
ORDER BY ORDER BY
sales.store_name ASC, ASC ASC, DESC;
-- 线下店铺年度销售金额、订单数量、退款金额、退款订单数、订单均价 -- 线下店铺年度销售金额、订单数量、退款金额、退款订单数、订单均价
SELECT SELECT
store_name as '店铺名称', store_code as '店铺编码',
YEAR(pay_date) as '年份', YEAR(pay_date) as '年份',
round(sum(CASE WHEN pay_amt > 0 THEN pay_amt ELSE 0 END), 2) as '销售金额', round(sum(CASE WHEN pay_amt > 0 THEN pay_amt ELSE 0 END), 2) as '销售金额',
count(CASE WHEN pay_amt > 0 THEN receipt_no ELSE NULL END) as '订单数量', count(CASE WHEN pay_amt > 0 THEN receipt_no ELSE NULL END) as '订单数量',
@@ -38,13 +92,13 @@ WHERE
pay_date >= '2022-01-01 00:00:00' pay_date >= '2022-01-01 00:00:00'
AND pay_date < '2025-07-01 00:00:00' AND pay_date < '2025-07-01 00:00:00'
GROUP BY GROUP BY
store_name, YEAR(pay_date) store_code, YEAR(pay_date)
ORDER BY ORDER BY
store_name ASC, ASC; store_code ASC, ASC;
-- 线上店铺月度销售金额 -- 线上店铺月度销售金额
SELECT SELECT
store_name as '店铺名称', store_code as '店铺编码',
YEAR(order_date) as '年份', YEAR(order_date) as '年份',
month(order_date) as '月份', month(order_date) as '月份',
round(sum(order_settle_amt),2) as '销售金额' round(sum(order_settle_amt),2) as '销售金额'
@@ -54,13 +108,13 @@ WHERE
order_date >= '2022-01-01 00:00:00' order_date >= '2022-01-01 00:00:00'
AND order_date <'2025-07-01 00:00:00' AND order_date <'2025-07-01 00:00:00'
GROUP BY GROUP BY
store_name,, store_code,,
order BY order BY
store_name, asc, asc store_code, asc, asc
-- 线下店铺月度销售金额 -- 线下店铺月度销售金额
SELECT SELECT
store_name as '店铺名称', store_code as '店铺编码',
year(pay_date) as '年份', year(pay_date) as '年份',
month(pay_date) as '月份', month(pay_date) as '月份',
round(sum(CASE WHEN pay_amt > 0 THEN pay_amt ELSE 0 END), 2) as '销售金额' round(sum(CASE WHEN pay_amt > 0 THEN pay_amt ELSE 0 END), 2) as '销售金额'
@@ -70,15 +124,15 @@ WHERE
pay_date >= '2022-01-01 00:00:00' pay_date >= '2022-01-01 00:00:00'
AND pay_date <'2025-07-01 00:00:00' AND pay_date <'2025-07-01 00:00:00'
GROUP BY GROUP BY
store_name,year(pay_date),month(pay_date) store_code,year(pay_date),month(pay_date)
order BY order BY
store_name, asc, asc store_code, asc, asc
-- 线上每年各产品数量、产品销售金额 -- 线上每年各产品数量、产品销售金额
SELECT SELECT
goods_barcode, goods_barcode,
year(order_date) as '年份', year(order_date) as '年份',
sum(good_qty) as '产品数量', sum(goods_qty) as '产品数量',
order_settle_amt as '销售金额' order_settle_amt as '销售金额'
FROM FROM
dwd_trade_hkaudit_ecommerce_sale_mt dwd_trade_hkaudit_ecommerce_sale_mt
@@ -91,35 +145,47 @@ order BY
goods_barcode,; goods_barcode,;
-- 线下每年各产品数量、产品销售金额 -- 线下每年各产品数量、产品销售金额
-- (订单号重复根据订单号groupby后失去产品信息小票支付表仅有订单号可关联如何计算)
-- 根据商品标价比例计算实际金额
SELECT
YEAR(b.pay_time) AS '年份',
a.goods_barcode AS '商品条码',
SUM(a.qty) AS '产品数量',
ROUND(SUM(b.total_real_amt * (a.goods_amt) / b.price_tag), 2) AS '销售金额'
FROM (
SELECT
platform_order_no,
goods_barcode,
goods_amt
price,
qty
FROM dwd_trade_hkaudit_shop_receipt_mt
) a
INNER JOIN(
SELECT
platform_order_no,
SUM(goods_amt) as price_tag
FROM dwd_trade_hkaudit_shop_receipt_mt
GROUP BY platform_order_no
) b
ON a.platform_order_no = b.platform_order_no
INNER JOIN (
SELECT
platform_order_no,
SUM(pay_amt) as total_real_amt
FROM dwd_trade_hkaudit_shop_receipt_pay_mt
GROUP BY platform_order_no
) c ON
a.platform_order_no = c.platform_order_no
GROUP BY
YEAR(b.pay_time), a.goods_barcode
ORDER BY
, DESC;
-- FROM(
-- SELECT
-- platform_order_no,
-- max(pay_date) as pay_time,
-- sum(pay_amt) as amount
-- FROM
-- dwd_trade_hkaudit_shop_receipt_pay_mt
-- WHERE
-- pay_date >='2022-01-01 00:00:00'
-- AND pay_date <'2025-07-01 00:00:00'
-- GROUP BY
-- platform_order_no
-- ) pay
-- left join(
-- SELECT
-- platform_order_no,
-- count(platform_order_no) as num
-- FROM
-- dwd_trade_hkaudit_shop_receipt_mt
-- GROUP BY
-- platform_order_no
-- ) order_num
-- on
-- pay.platform_order_no = order_num.platform_order_no
-- 线上每年前五店铺金额分布 -- 线上每年前五店铺金额分布
SELECT SELECT
store_name as '店铺名称', store_code as '店铺编码',
sum(order_settle_amt) as '销售金额' sum(order_settle_amt) as '销售金额'
FROM FROM
dwd_trade_hkaudit_ecommerce_sale_mt dwd_trade_hkaudit_ecommerce_sale_mt
@@ -127,14 +193,14 @@ WHERE
order_date >= '2022-01-01 00:00:00' order_date >= '2022-01-01 00:00:00'
AND order_date < '2023-01-01 00:00:00' AND order_date < '2023-01-01 00:00:00'
GROUP BY GROUP BY
store_name store_code
order BY order BY
sum(order_settle_amt) desc sum(order_settle_amt) desc
LIMIT 5 LIMIT 5
-- 线下每年前五店铺金额分布 -- 线下每年前五店铺金额分布
SELECT SELECT
store_name as '店铺名称', store_code as '店铺编码',
round(sum(CASE WHEN pay_amt > 0 THEN pay_amt ELSE 0 END), 2) as '销售金额' round(sum(CASE WHEN pay_amt > 0 THEN pay_amt ELSE 0 END), 2) as '销售金额'
FROM FROM
dwd_trade_hkaudit_shop_receipt_pay_mt dwd_trade_hkaudit_shop_receipt_pay_mt
@@ -142,9 +208,9 @@ WHERE
pay_date >= '2022-01-01 00:00:00' pay_date >= '2022-01-01 00:00:00'
AND pay_date <'2023-01-01 00:00:00' AND pay_date <'2023-01-01 00:00:00'
GROUP BY GROUP BY
order BY order BY
线 desc desc
LIMIT 5 LIMIT 5
-- 线上每年各省份销售金额、订单数量 -- 线上每年各省份销售金额、订单数量
@@ -163,37 +229,63 @@ GROUP BY
-- 线下每年各店铺所在省份销售金额、订单数量 -- 线下每年各店铺所在省份销售金额、订单数量
-- (如何确认店铺所在省份?) -- (如何确认店铺所在省份?)
SELECT
store_code as '店铺编码',
round(sum(CASE WHEN pay_amt > 0 THEN pay_amt ELSE 0 END), 2) as '销售金额'
FROM
dwd_trade_hkaudit_shop_receipt_pay_mt
WHERE
pay_date >= '2022-01-01 00:00:00'
AND pay_date <'2023-01-01 00:00:00'
GROUP BY
order BY
desc
-- 线上每年单笔订单金额分布 -- 线上每年单笔订单金额分布
-- (并单如何考虑单笔金额?) -- (并单如何考虑单笔金额?)
-- 单个订单号使用订单均摊金额,并单号均分金额
SELECT SELECT
YEAR(order_date) AS '年份', YEAR(a.order_date) AS '年份',
a.money_area AS '单笔订单金额', a.money_area AS '单笔订单金额',
count(a.platform_order_no) as '订单数量', count(a.split_item) as '订单数量',
ROUND(sum(a.order_settle_amt),2) AS '销售金额' ROUND(sum(a.split_amount),2) AS '销售金额'
FROM( FROM(
SELECT SELECT
order_settle_amt, single.split_amount,
platform_order_no, single.split_item,
single.order_date,
CASE CASE
WHEN order_settle_amt >0 AND order_settle_amt <10 THEN '0-10' WHEN single.split_amount >0 AND single.split_amount <10 THEN '0-10'
WHEN order_settle_amt >=10 AND order_settle_amt <50 THEN '10-50' WHEN single.split_amount >=10 AND single.split_amount <50 THEN '10-50'
WHEN order_settle_amt >=50 AND order_settle_amt <100 THEN '50-100' WHEN single.split_amount >=50 AND single.split_amount <100 THEN '50-100'
WHEN order_settle_amt >=100 AND order_settle_amt <500 THEN '100-500' WHEN single.split_amount >=100 AND single.split_amount <500 THEN '100-500'
WHEN order_settle_amt >=500 AND order_settle_amt <1000 THEN '500-1000' WHEN single.split_amount >=500 AND single.split_amount <1000 THEN '500-1000'
WHEN order_settle_amt >=1000 AND order_settle_amt <5000 THEN '1000-5000' WHEN single.split_amount >=1000 AND single.split_amount <5000 THEN '1000-5000'
WHEN order_settle_amt >=5000 AND order_settle_amt <10000 THEN '5000-10000' WHEN single.split_amount >=5000 AND single.split_amount <10000 THEN '5000-10000'
WHEN order_settle_amt >=10000 THEN '10000及以上' WHEN single.split_amount >=10000 THEN '10000及以上'
END AS money_area END AS money_area
FROM FROM(
dwd_trade_hkaudit_ecommerce_sale_mt SELECT
WHERE order_date,
order_date >='2022-01-01 00:00:00' split_item,
AND order_date <'2025-07-01 00:00:00' goods_amt / length(split_array) as split_amount -- 金额均分
) a FROM (
SELECT
order_date,
goods_amt,
splitByChar(',', platform_order_no) as split_array
FROM
dwd_trade_hkaudit_ecommerce_sale_mt
WHERE
order_date >='2022-01-01 00:00:00'
AND order_date <'2025-07-01 00:00:00'
) single
ARRAY JOIN split_array AS split_item
)
) a
GROUP BY GROUP BY
a.money_area YEAR(a.order_date),a.money_area
ORDER BY ORDER BY
, ,
CASE a.money_area CASE a.money_area
@@ -249,7 +341,18 @@ ORDER BY
END; END;
-- 线上每年同一个收货地址销售金额、订单数量(需考虑脱敏情况) -- 线上每年同一个收货地址销售金额、订单数量(需考虑脱敏情况)
SELECT
round(sum(sales.order_settle_amt),2) as '销售金额',
COUNT(sales.platform_order_no) +
SUM(LENGTH(sales.platform_order_no) - LENGTH(REPLACE(sales.platform_order_no, ',', ''))) as '订单数量'
FROM
dwd_trade_hkaudit_ecommerce_sale_mt
WHERE
order_date >='2022-01-01 00:00:00'
AND order_date <'2025-07-01 00:00:00'
GROUP BY
-- 线上每年各天和各小时订单数和销售金额 -- 线上每年各天和各小时订单数和销售金额
-- 各天 -- 各天
@@ -296,7 +399,7 @@ FROM(
SELECT SELECT
platform_order_no, platform_order_no,
max(pay_date) as pay_time, max(pay_date) as pay_time,
sum(pay_amt) as amount round(sum(CASE WHEN pay_amt > 0 THEN pay_amt ELSE 0 END), 2) as amount
FROM FROM
dwd_trade_hkaudit_shop_receipt_pay_mt dwd_trade_hkaudit_shop_receipt_pay_mt
WHERE WHERE
@@ -331,7 +434,7 @@ FROM (
SELECT SELECT
platform_order_no, platform_order_no,
MAX(pay_date) as pay_time, MAX(pay_date) as pay_time,
SUM(pay_amt) as amount sum(CASE WHEN pay_amt > 0 THEN pay_amt ELSE 0 END) as amount
FROM FROM
dwd_trade_hkaudit_shop_receipt_pay_mt dwd_trade_hkaudit_shop_receipt_pay_mt
WHERE WHERE
@@ -358,7 +461,7 @@ ORDER BY
-- 线上每年大促期间店铺销售金额、订单数量 -- 线上每年大促期间店铺销售金额、订单数量
SELECT SELECT
store_name as '店铺名称', store_code as '店铺编码',
YEAR(order_date) AS '年份', YEAR(order_date) AS '年份',
CASE CASE
WHEN (MONTH(order_date) = 6 AND DAY(order_date) BETWEEN 15 AND 21) THEN '父亲节' WHEN (MONTH(order_date) = 6 AND DAY(order_date) BETWEEN 15 AND 21) THEN '父亲节'
@@ -377,8 +480,8 @@ WHERE order_date >= '2022-01-01 00:00:00'
(MONTH(order_date) = 6 AND DAY(order_date) BETWEEN 10 AND 20) OR -- 618 (MONTH(order_date) = 6 AND DAY(order_date) BETWEEN 10 AND 20) OR -- 618
(MONTH(order_date) = 11 AND DAY(order_date) BETWEEN 1 AND 15) -- 双11 (MONTH(order_date) = 11 AND DAY(order_date) BETWEEN 1 AND 15) -- 双11
) )
GROUP BY store_name, YEAR(order_date), GROUP BY store_code, YEAR(order_date),
ORDER BY store_name ASC, ASC, ORDER BY store_code ASC, ASC,
CASE CASE
WHEN '大促类型' = '父亲节' THEN 1 WHEN '大促类型' = '父亲节' THEN 1
WHEN '大促类型' = '618' THEN 2 WHEN '大促类型' = '618' THEN 2
@@ -386,19 +489,155 @@ ORDER BY store_name ASC, 年份 ASC,
END; END;
-- 线下每年大促期间店铺销售金额、订单数量 -- 线下每年大促期间店铺销售金额、订单数量
SELECT
year(pay_time) as '年份',
pay.store as '店铺编码',
CASE
WHEN (MONTH(pay.pay_time) = 6 AND DAY(pay.pay_time) BETWEEN 15 AND 21) THEN '父亲节'
WHEN (MONTH(pay.pay_time) = 6 AND DAY(pay.pay_time) BETWEEN 10 AND 20) THEN '618'
WHEN (MONTH(pay.pay_time) = 11 AND DAY(pay.pay_time) BETWEEN 1 AND 15) THEN '双11'
ELSE '其他'
END as '大促类型',
ROUND(SUM(pay.amount), 2) as '销售金额',
sum(order_num.num) as '订单数量'
FROM(
SELECT
platform_order_no,
max(store_code) as store,
max(pay_date) as pay_time,
sum(CASE WHEN pay_amt > 0 THEN pay_amt ELSE 0 END) as amount
FROM
dwd_trade_hkaudit_shop_receipt_pay_mt
WHERE
pay_date >='2022-01-01 00:00:00'
AND pay_date <'2025-07-01 00:00:00'
AND (
(MONTH(pay_date) = 6 AND DAY(pay_date) BETWEEN 15 AND 21) OR -- 父亲节
(MONTH(pay_date) = 6 AND DAY(pay_date) BETWEEN 10 AND 20) OR -- 618
(MONTH(pay_date) = 11 AND DAY(pay_date) BETWEEN 1 AND 15) -- 双11
)
GROUP BY
platform_order_no
) pay
left join(
SELECT
platform_order_no,
count(platform_order_no) as num
FROM
dwd_trade_hkaudit_shop_receipt_mt
GROUP BY
platform_order_no
) order_num
on
pay.platform_order_no = order_num.platform_order_no
GROUP BY store_code, YEAR(order_date),
ORDER BY store_code, ,
CASE
WHEN '大促类型' = '父亲节' THEN 1
WHEN '大促类型' = '618' THEN 2
WHEN '大促类型' = '双11' THEN 3
END;
-- 线上每年订单下单和发货间隔的销售金额、订单数量分布 -- 线上每年订单下单和发货间隔的销售金额、订单数量分布
-- (并单如何考虑下单时间?)
-- 视为同一时间下单
SELECT
CASE timestampdiff(day,deliver_date,order_date)
WHEN 0 THEN '当天'
WHEN 1 THEN '1天'
WHEN 2 THEN '2天'
WHEN 3 THEN '3天'
WHEN 4 THEN '4天'
ELSE '5天及以上'
END AS '发货间隔',
SUM(order_settle_amt) AS '销售金额',
COUNT(platform_order_no) +
SUM(LENGTH(platform_order_no) - LENGTH(REPLACE(platform_order_no, ',', ''))) AS '订单数量'
FROM
dwd_trade_hkaudit_ecommerce_sale_mt sales
WHERE
order_date >= '2022-01-01 00:00:00'
AND order_date < '2025-07-31 00:00:00'
GROUP BY
ORDER BY
CASE
WHEN '当天' THEN 1
WHEN '1天' THEN 2
WHEN '2天' THEN 3
WHEN '3天' THEN 4
WHEN '4天' THEN 5
WHEN '5天及以上' THEN 6
END;
-- 线上每年各物流承运商销售金额、订单数量 -- 线上每年各物流承运商销售金额、订单数量
SELECT
year(sales.order_date) AS '年份',
carrier as '物流承运商',
round(sum(sales.order_settle_amt),2) as '销售金额',
COUNT(sales.platform_order_no) +
SUM(LENGTH(sales.platform_order_no) - LENGTH(REPLACE(sales.platform_order_no, ',', ''))) as '订单数量'
FROM
dwd_trade_hkaudit_ecommerce_sale_mt sales
WHERE
order_date >= '2022-01-01 00:00:00'
AND order_date < '2025-07-31 00:00:00'
GROUP BY
year(sales.order_date), carrier
order BY , carrier;
-- 线上每年退款大于原销售的差异金额、订单数量 -- 线上每年退款大于原销售的差异金额、订单数量
SELECT
store_code AS '店铺编码',
YEAR(order_date) AS '年份',
ROUND(SUM(excess_refund), 2) AS '差异金额',
COUNT(*) AS '订单数量'
FROM (
SELECT
s.store_code,
s.order_date,
s.order_settle_amt AS sale_amt,
COALESCE(r.return_amt, 0) + COALESCE(c.change_amt, 0) AS refund_amt,
CASE
WHEN (COALESCE(r.return_amt, 0) + COALESCE(c.change_amt, 0)) > ABS(s.order_settle_amt)
THEN (COALESCE(r.return_amt, 0) + COALESCE(c.change_amt, 0)) - ABS(s.order_settle_amt)
ELSE 0
END AS excess_refund
FROM dwd_trade_hkaudit_ecommerce_sale_mt s
LEFT JOIN (
SELECT platform_order_no, SUM(return_goods_amt) AS return_amt
FROM dwd_trade_hkaudit_ecommerce_sale_return_mt
GROUP BY platform_order_no
) r ON s.platform_order_no = r.platform_order_no
LEFT JOIN (
SELECT platform_order_no, SUM(special_barcode_amt) AS change_amt
FROM dwd_trade_hkaudit_ecommerce_sale_change_mt
GROUP BY platform_order_no
) c ON s.platform_order_no = c.platform_order_no
WHERE (r.return_amt IS NOT NULL OR c.change_amt IS NOT NULL)
AND s.order_date >= '2022-01-01 00:00:00'
AND s.order_date < '2025-07-01 00:00:00'
) excess_data
WHERE excess_refund > 0
GROUP BY store_code, YEAR(order_date)
ORDER BY , 退 DESC;
-- 线下每年退款大于原销售的差异金额、订单数量 -- 线下每年退款大于原销售的差异金额、订单数量
======= SELECT
SELECT * FROM a;113333sss YEAR(pay_time) AS '年份',
>>>>>>> bcf2f3cd58c4c0fbd7ef580d305440999d743a5d SUM(total_refund - total_sale) AS '差异金额',
COUNT(*) AS '订单数量'
FROM (
SELECT
receipt_no,
SUM(CASE WHEN pay_amt > 0 THEN pay_amt ELSE 0 END) AS total_sale,
SUM(CASE WHEN pay_amt < 0 THEN ABS(pay_amt) ELSE 0 END) AS total_refund,
MAX(pay_date) AS pay_time
FROM dwd_trade_hkaudit_shop_receipt_pay_mt
GROUP BY receipt_no
HAVING total_refund > total_sale
)
GROUP BY YEAR(pay_time);

Binary file not shown.

Binary file not shown.

After

Width:  |  Height:  |  Size: 260 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 227 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 271 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 232 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 223 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 45 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 527 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 179 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 200 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 212 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 209 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 198 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 44 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 508 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 208 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 187 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 227 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 209 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 196 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 45 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 535 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 251 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 227 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 252 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 234 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 194 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 45 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 508 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 208 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 185 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 224 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 209 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 196 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 44 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 512 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 209 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 188 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 224 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 211 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 195 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 44 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 522 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 245 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 229 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 260 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 195 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 182 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 44 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 510 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 207 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 192 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 226 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 196 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 186 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 44 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 515 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 188 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 201 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 218 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 207 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 193 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 44 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 505 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 192 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 195 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 217 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 204 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 211 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 45 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 511 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 192 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 200 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 183 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 167 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 189 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 175 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 175 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 172 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 188 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 173 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 174 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 175 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 175 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 201 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 191 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 193 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 190 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 188 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 198 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 185 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 186 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 194 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 185 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 187 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 189 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 186 KiB

Some files were not shown because too many files have changed in this diff Show More