优化门店月度趋势接口性能索引.sql
2.45 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
-- ============================================
-- 优化 get-store-monthly-trend 接口性能的索引
-- ============================================
-- 说明:这些索引专门为门店月度趋势接口优化
-- 执行前请检查索引是否已存在,避免重复创建
-- ============================================
-- 1. lq_kd_kdjlb (开单记录表) 索引
-- ============================================
-- 用于:开单业绩按月统计
-- 查询条件:djmd (门店ID), F_IsEffective, kdrq (开单日期)
-- 分组:DATE_FORMAT(kdrq, '%Y%m')
-- 索引:用于门店+时间范围查询(如果已存在 idx_kd_kdjlb_store_date_effective 可跳过)
-- CREATE INDEX IF NOT EXISTS idx_kd_kdjlb_store_date_effective
-- ON lq_kd_kdjlb(djmd, kdrq, F_IsEffective);
-- 补充索引:用于月份分组查询(优化GROUP BY性能)
CREATE INDEX IF NOT EXISTS idx_kd_kdjlb_store_date_month
ON lq_kd_kdjlb(djmd, F_IsEffective, kdrq);
-- ============================================
-- 2. lq_xh_hyhk (耗卡记录表) 索引
-- ============================================
-- 用于:消耗业绩按月统计
-- 查询条件:md (门店ID), F_IsEffective, hksj (耗卡时间)
-- 分组:DATE_FORMAT(hksj, '%Y%m')
-- 索引:用于门店+时间范围查询
CREATE INDEX IF NOT EXISTS idx_xh_hyhk_store_date_month
ON lq_xh_hyhk(md, F_IsEffective, hksj);
-- ============================================
-- 3. lq_hytk_hytk (退卡表) 索引
-- ============================================
-- 用于:退卡金额按月统计
-- 查询条件:md (门店ID), F_IsEffective, tksj (退卡时间)
-- 分组:DATE_FORMAT(tksj, '%Y%m')
-- 索引:用于门店+时间范围查询(如果已存在 idx_hytk_effective_date 可跳过)
-- CREATE INDEX IF NOT EXISTS idx_hytk_effective_date
-- ON lq_hytk_hytk(F_IsEffective, tksj);
-- 补充索引:用于门店+时间范围查询(优化门店维度查询)
CREATE INDEX IF NOT EXISTS idx_hytk_store_date_month
ON lq_hytk_hytk(md, F_IsEffective, tksj);
-- ============================================
-- 4. 验证索引创建
-- ============================================
-- 验证索引是否创建成功
-- SELECT
-- TABLE_NAME,
-- INDEX_NAME,
-- COLUMN_NAME,
-- SEQ_IN_INDEX
-- FROM INFORMATION_SCHEMA.STATISTICS
-- WHERE TABLE_SCHEMA = DATABASE()
-- AND TABLE_NAME IN ('lq_kd_kdjlb', 'lq_xh_hyhk', 'lq_hytk_hytk')
-- AND INDEX_NAME LIKE 'idx_%'
-- ORDER BY TABLE_NAME, INDEX_NAME, SEQ_IN_INDEX;