优化金三角业绩排行榜接口性能索引.sql 2.62 KB
-- ============================================
-- 优化 get-gold-triangle-performance-ranking 接口性能的索引
-- ============================================
-- 说明:这些索引专门为金三角业绩排行榜接口优化
-- 执行前请检查索引是否已存在,避免重复创建

-- ============================================
-- 1. lq_ycsd_jsj (金三角设定表) 索引
-- ============================================
-- 用于:WHERE jsj.yf = @StatisticsMonth 查询条件
-- 查询条件:yf (月份)

-- 索引:用于月份查询(最常用)
CREATE INDEX IF NOT EXISTS idx_ycsd_jsj_yf 
ON lq_ycsd_jsj(yf);

-- ============================================
-- 2. lq_jinsanjiao_user (金三角用户绑定表) 索引
-- ============================================
-- 用于:JOIN和过滤条件
-- 查询条件:status = 'ACTIVE', F_DeleteMark = 0, user_id (用于JOIN)

-- 索引1:用于JOIN和状态过滤(最常用)
CREATE INDEX IF NOT EXISTS idx_jinsanjiao_user_user_status_delete 
ON lq_jinsanjiao_user(user_id, status, F_DeleteMark);

-- 索引2:用于反向JOIN(jsj_id用于关联金三角设定)
CREATE INDEX IF NOT EXISTS idx_jinsanjiao_user_jsj_status_delete 
ON lq_jinsanjiao_user(jsj_id, status, F_DeleteMark);

-- ============================================
-- 3. lq_kd_jksyj (开单健康师业绩表) 索引
-- ============================================
-- 用于:JOIN和过滤条件
-- 查询条件:jkszh (用于JOIN), F_IsEffective = 1

-- 索引:用于JOIN和有效性过滤
CREATE INDEX IF NOT EXISTS idx_kd_jksyj_jkszh_effective 
ON lq_kd_jksyj(jkszh, F_IsEffective);

-- ============================================
-- 4. lq_kd_kdjlb (开单记录表) 索引
-- ============================================
-- 用于:JOIN和过滤条件
-- 查询条件:F_Id (用于JOIN), F_IsEffective = 1, kdrq (时间范围)

-- 索引:用于JOIN、有效性过滤和时间范围查询
-- 注意:如果 idx_kd_kdjlb_store_date_effective 已存在,此索引可能冗余
-- 但为了JOIN性能,保留此索引
CREATE INDEX IF NOT EXISTS idx_kd_kdjlb_id_effective_date 
ON lq_kd_kdjlb(F_Id, F_IsEffective, kdrq);

-- ============================================
-- 5. 验证索引创建
-- ============================================
-- 验证索引是否创建成功
-- SELECT 
--     TABLE_NAME,
--     INDEX_NAME,
--     COLUMN_NAME,
--     SEQ_IN_INDEX
-- FROM INFORMATION_SCHEMA.STATISTICS
-- WHERE TABLE_SCHEMA = DATABASE()
--     AND TABLE_NAME IN ('lq_ycsd_jsj', 'lq_jinsanjiao_user', 'lq_kd_jksyj', 'lq_kd_kdjlb')
--     AND INDEX_NAME LIKE 'idx_%'
-- ORDER BY TABLE_NAME, INDEX_NAME, SEQ_IN_INDEX;