MySql lower_case_table_names迷思
这篇讲的是从Oracle或SQL Server迁移到MySQL时,一个常被忽略的“大小写敏感”坑。作者从实际迁移项目出发,指出纠结`lower_case_table_names`设置的根源在于不同数据库系统的默认行为差异——MySQL在Linux下默认区分大小写。 他给出的实战建议很明确:优先在代码层面统一表名大小写(全大写或全小写),然后再迁移数据库,这样能保持`lower_case_table_names=0`的默认安全设置。如果时间紧张无法修改代码,只能先妥协设置`lower_case_table_names=1`,但务必在项目后期通过开启`general log`逐步排查和修正不规范的SQL。 文章最后强烈呼吁,在制定数据库规范时就该强制统一表名大小写,避免混合写法带来的无尽麻烦。这个观点对于所有需要跨平台迁移或维护规范的团队,都有直接的参考价值。