-- auto_put_ad_mini 数据库表结构 -- 数据库类型:MySQL 5.7+ -- 字符集:utf8mb4 -- ===================================================== -- 1. 账户白名单表 -- ===================================================== CREATE TABLE IF NOT EXISTS account_whitelist ( id BIGINT AUTO_INCREMENT PRIMARY KEY COMMENT '自增主键', account_id BIGINT NOT NULL COMMENT '腾讯广告账户ID', account_name VARCHAR(200) DEFAULT NULL COMMENT '账户名称(备注用)', business_line VARCHAR(100) DEFAULT NULL COMMENT '业务线(用于分组管理)', enabled BOOLEAN DEFAULT TRUE COMMENT '是否启用(1=启用,0=禁用)', remark TEXT DEFAULT NULL COMMENT '备注说明', created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间', created_by VARCHAR(100) DEFAULT NULL COMMENT '创建人', updated_by VARCHAR(100) DEFAULT NULL COMMENT '更新人', UNIQUE KEY uk_account_id (account_id), KEY idx_enabled (enabled), KEY idx_business_line (business_line), KEY idx_updated_at (updated_at) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='广告账户白名单'; -- ===================================================== -- 2. 系统配置表(Key-Value 存储) -- ===================================================== CREATE TABLE IF NOT EXISTS system_config ( id INT AUTO_INCREMENT PRIMARY KEY COMMENT '自增主键', config_key VARCHAR(100) NOT NULL COMMENT '配置键(如 execution_enabled, cron_schedule)', config_value TEXT NOT NULL COMMENT '配置值(JSON 或字符串)', value_type ENUM('string', 'boolean', 'int', 'json') DEFAULT 'string' COMMENT '值类型', description VARCHAR(500) DEFAULT NULL COMMENT '配置说明', enabled BOOLEAN DEFAULT TRUE COMMENT '是否启用', created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间', updated_by VARCHAR(100) DEFAULT NULL COMMENT '更新人', UNIQUE KEY uk_config_key (config_key), KEY idx_enabled (enabled) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='系统配置表'; -- ===================================================== -- 3. 决策历史记录表(可选,用于审计和分析) -- ===================================================== CREATE TABLE IF NOT EXISTS decision_history ( id BIGINT AUTO_INCREMENT PRIMARY KEY COMMENT '自增主键', decision_date DATE NOT NULL COMMENT '决策日期', account_id BIGINT NOT NULL COMMENT '账户ID', ad_id BIGINT NOT NULL COMMENT '广告ID', ad_name VARCHAR(500) DEFAULT NULL COMMENT '广告名称', action VARCHAR(50) NOT NULL COMMENT '决策动作(pause, bid_down, bid_up, scale_up, observe, hold)', dimension VARCHAR(100) DEFAULT NULL COMMENT '决策维度(roi, fission, decay等)', reason TEXT DEFAULT NULL COMMENT '决策理由', current_bid DECIMAL(10, 2) DEFAULT NULL COMMENT '当前出价(元)', recommended_bid DECIMAL(10, 2) DEFAULT NULL COMMENT '推荐出价(元)', recommended_change_pct DECIMAL(6, 2) DEFAULT NULL COMMENT '调整幅度(%)', roi_7d DECIMAL(10, 4) DEFAULT NULL COMMENT '7日ROI', dynamic_roi DECIMAL(10, 4) DEFAULT NULL COMMENT '动态ROI', cost_7d_avg DECIMAL(10, 2) DEFAULT NULL COMMENT '7日均消耗(元)', executed BOOLEAN DEFAULT FALSE COMMENT '是否已执行', execution_status VARCHAR(50) DEFAULT NULL COMMENT '执行状态(success, failed, pending, skipped)', execution_error TEXT DEFAULT NULL COMMENT '执行错误信息', executed_at TIMESTAMP NULL DEFAULT NULL COMMENT '执行时间', created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', KEY idx_decision_date (decision_date), KEY idx_account_id (account_id), KEY idx_ad_id (ad_id), KEY idx_action (action), KEY idx_executed (executed), KEY idx_created_at (created_at) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='决策历史记录'; -- ===================================================== -- 初始化数据 -- ===================================================== -- 插入默认系统配置 INSERT INTO system_config (config_key, config_value, value_type, description) VALUES ('execution_enabled', 'false', 'boolean', '是否启用实际执行(生产环境谨慎开启)'), ('whitelist_enabled', 'true', 'boolean', '是否启用白名单机制'), ('cron_schedule', '0 2 * * *', 'string', 'APScheduler定时调度表达式(每天凌晨2点UTC)'), ('run_on_startup', 'false', 'boolean', '服务启动时是否立即执行一次'), ('max_concurrent_tasks', '1', 'int', '最大并发任务数'), ('approval_timeout_minutes', '30', 'int', '飞书审批超时时间(分钟)'), ('roi_low_factor', '0.75', 'string', '关停线系数(ROI < 渠道P50 * 0.75 触发关停)'), ('bid_down_roi_factor', '0.90', 'string', '降价线系数(ROI < 渠道P50 * 0.90 触发降价)'), ('bid_up_roi_factor', '1.05', 'string', '提价线系数(ROI > 渠道P50 * 1.05 触发提价)') ON DUPLICATE KEY UPDATE updated_at = CURRENT_TIMESTAMP; -- 插入示例白名单账户(请根据实际情况修改) INSERT INTO account_whitelist (account_id, account_name, business_line, enabled, remark, created_by) VALUES (80769799, '测试账户1', '小程序投流', TRUE, '初始白名单账户', 'system'), (71305011, '测试账户2', '小程序投流', TRUE, '初始白名单账户', 'system') ON DUPLICATE KEY UPDATE updated_at = CURRENT_TIMESTAMP; -- ===================================================== -- 索引优化说明 -- ===================================================== -- 1. account_whitelist.uk_account_id: 保证账户唯一性 -- 2. system_config.uk_config_key: 保证配置键唯一性 -- 3. decision_history.idx_decision_date: 按日期查询决策记录 -- 4. decision_history.idx_ad_id: 查询某个广告的历史决策 -- 5. decision_history.idx_action: 按决策类型统计分析 -- ===================================================== -- 表分区建议(如数据量大) -- ===================================================== -- ALTER TABLE decision_history PARTITION BY RANGE (YEAR(decision_date) * 100 + MONTH(decision_date)) ( -- PARTITION p202604 VALUES LESS THAN (202605), -- PARTITION p202605 VALUES LESS THAN (202606), -- PARTITION p202606 VALUES LESS THAN (202607), -- PARTITION pmax VALUES LESS THAN MAXVALUE -- );