check_laundry_flow_time_issue.py 4.13 KB
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
"""
检查洗毛巾记录的时间字段差异问题
比较CreateTime和SendTime的差异
"""

import pymysql
from datetime import datetime

# 数据库配置
DB_CONFIG = {
    'host': 'rm-2vccze142rc9a8f58bo.mysql.cn-chengdu.rds.aliyuncs.com',
    'port': 3306,
    'user': 'lvqiansql',
    'password': 'LvQ1@n!20251211',
    'database': 'lqerp_dev',
    'charset': 'utf8mb4',
    'connect_timeout': 60,
    'read_timeout': 300,
    'write_timeout': 300
}

def check_time_issue():
    """检查时间字段差异"""
    connection = None
    try:
        connection = pymysql.connect(**DB_CONFIG)
        cursor = connection.cursor(pymysql.cursors.DictCursor)
        
        store_id = '1649328471923847187'
        month_str = '202512'
        
        # 查询所有相关记录
        sql = """
        SELECT 
            F_Id,
            F_BatchNumber,
            F_FlowType,
            F_ProductType,
            F_Quantity,
            F_TotalPrice,
            F_CreateTime,
            F_SendTime,
            COALESCE(F_SendTime, F_CreateTime) as StatTime,
            DATE_FORMAT(F_CreateTime, '%%Y%%m') as CreateMonth,
            DATE_FORMAT(COALESCE(F_SendTime, F_CreateTime), '%%Y%%m') as StatMonth
        FROM lq_laundry_flow
        WHERE F_IsEffective = 1
            AND F_FlowType = 0
            AND F_StoreId = %s
            AND (
                DATE_FORMAT(F_CreateTime, '%%Y%%m') = %s
                OR DATE_FORMAT(COALESCE(F_SendTime, F_CreateTime), '%%Y%%m') = %s
            )
        ORDER BY COALESCE(F_SendTime, F_CreateTime)
        """
        
        cursor.execute(sql, (store_id, month_str, month_str))
        records = cursor.fetchall()
        
        print("=" * 120)
        print("洗毛巾记录时间字段差异检查")
        print("=" * 120)
        print(f"\n查询条件:门店ID={store_id}, 月份={month_str}")
        print(f"\n共查询到 {len(records)} 条记录\n")
        
        # 按CreateTime统计
        create_time_records = [r for r in records if r['CreateMonth'] == month_str]
        print(f"按CreateTime过滤(12月创建): {len(create_time_records)} 条")
        
        # 按StatTime统计(工资计算使用的逻辑)
        stat_time_records = [r for r in records if r['StatMonth'] == month_str]
        print(f"按StatTime过滤(12月统计): {len(stat_time_records)} 条")
        
        # 找出差异
        create_time_ids = {r['F_Id'] for r in create_time_records}
        stat_time_ids = {r['F_Id'] for r in stat_time_records}
        
        diff_ids = stat_time_ids - create_time_ids
        if diff_ids:
            print(f"\n⚠️  差异记录(StatTime在12月,但CreateTime不在12月): {len(diff_ids)} 条")
            print("-" * 120)
            print(f"{'批次号':<20} {'产品类型':<10} {'CreateTime':<20} {'SendTime':<20} {'总费用':<10}")
            print("-" * 120)
            diff_total = 0
            for r in records:
                if r['F_Id'] in diff_ids:
                    print(f"{r['F_BatchNumber']:<20} "
                          f"{r['F_ProductType'] or '':<10} "
                          f"{str(r['F_CreateTime']):<20} "
                          f"{str(r['F_SendTime'] or ''):<20} "
                          f"{r['F_TotalPrice']:<10.2f}")
                    diff_total += r['F_TotalPrice']
            print("-" * 120)
            print(f"差异金额总计: {diff_total:.2f} 元")
        
        # 汇总统计
        create_total = sum(r['F_TotalPrice'] for r in create_time_records)
        stat_total = sum(r['F_TotalPrice'] for r in stat_time_records)
        
        print(f"\n汇总统计:")
        print(f"  按CreateTime统计金额: {create_total:.2f} 元")
        print(f"  按StatTime统计金额: {stat_total:.2f} 元")
        print(f"  差异金额: {stat_total - create_total:.2f} 元")
        
        return records
        
    except Exception as e:
        print(f"查询失败: {str(e)}")
        import traceback
        traceback.print_exc()
        return None
    finally:
        if connection:
            connection.close()

if __name__ == '__main__':
    check_time_issue()