MySQL触发器实现简单的分表逻辑_垂直分表与自动化路由

MySQL触发器中禁止使用PREPARE/EXECUTE动态建表,因引擎限制而非权限问题;须预建分表、显式字段插入、合理选用BEFORE/AFTER时机,并控制路由逻辑与索引以保障性能与数据一致性。触发器里不能用 PREPARE / EXECUTE 动态建表MySQL 触发器执行时处于语句上下文锁定状态,不支持动态 SQL。想在 INSERT 触发器里根据时间自动创建新分表(比如 t_log_202410),会直接报错:ERROR 1336 (0A000): Dynamic SQL is not allowed in stored function or trigger。这不是权限问题,是引擎限制。实操建议:分表动作必须提前完成------上线前按业务周期(如月/周)预建好未来 6--12 个月的表,命名统一,如 t_log_202410、t_log_202411触发器只做路由判断和 INSERT 转发,不参与建表用外部脚本(Python/Shell)定期检查并补全缺失分表,配合 cron 执行,别塞进触发器INSERT ... SELECT 路由到目标分表时字段顺序必须严格一致垂直分表后,主表和子表字段不完全重叠,但触发器里用 INSERT INTO t_log_202410 (...) SELECT ... 转发时,若字段名、数量、顺序稍有出入,就会静默丢数据或报错 Column count doesn't match value count。常见错误现象:主表加了新字段,但没同步到所有分表结构,触发器 INSERT 失败SELECT 子句漏写某个非空字段,导致插入失败(尤其 NOT NULL 字段)用了 * ------ 绝对禁止!字段顺序不可控,且不同分表结构可能已分化实操建议:触发器中显式列出所有目标字段:INSERT INTO t_log_202410 (id, uid, content, created_at) SELECT NEW.id, NEW.uid, NEW.content, NEW.created_at所有分表用相同 DDL 初始化,后续字段变更必须原子化同步(用 pt-online-schema-change 或带锁升级)用视图或存储过程封装 INSERT 逻辑?不行------触发器里不能调用含 SQL 的存储过程NEW 和 OLD 在 BEFORE/AFTER 触发器中的可用性差异垂直分表常需在插入前生成 ID 或补全字段(比如把 created_at 设为 NOW()),这时必须用 BEFORE INSERT;若想基于刚插入的主键再写日志,则得用 AFTER INSERT。但两者能访问的记录状态完全不同。关键区别: 知网AI智能写作 知网AI智能写作,写文档、写报告如此简单

相关推荐
java修仙传2 小时前
从手写 Redis 锁到 Redisson:我对分布式锁安全性的理解
java·数据库·redis·分布式
oh LAN2 小时前
Windows 下 Redis 开机自启
数据库·windows·redis
2301_817672262 小时前
mysql如何批量增加表的字段_脚本化DDL操作实践
jvm·数据库·python
Engineer邓祥浩2 小时前
JVM学习笔记(9) 第三部分 虚拟机执行子系统 第8章 虚拟机字节码执行引擎
jvm·笔记·学习
专注VB编程开发20年2 小时前
万能数据库格式转换,导入导出表格,主键索引
数据库
DaqunChen2 小时前
mysql存储引擎性能基准测试_InnoDB与MyISAM对比指南
jvm·数据库·python
2301_782659182 小时前
CSS Flex布局中如何实现导航栏与Logo的左右分布_利用justify-content- space-between
jvm·数据库·python
mailangduoduo2 小时前
实战对比PyTorch VS PyTorch Lighting以MNIST为例
人工智能·pytorch·python·深度学习·图像分类·全连接网络
Qy_cm2 小时前
pytorch+vit基础结构
人工智能·pytorch·python