MySQL表名大小写敏感由lower_case_table_names系统变量决定:Linux默认0(区分)、Windows为1(不区分)、macOS为2(创建转小写、比较不区分);修改需初始化时设置或清空datadir后重启,线上库不可热改,开发应统一用小写表名并显式加反引号。MySQL 表名大小写敏感由什么决定直接看 lower_case_table_names 系统变量,它不是"开关",而是定义表名在磁盘和内存中如何存储与比较的策略。Linux 默认值是 0(区分大小写),Windows 是 1(不区分),macOS 是 2(创建时转小写,比较时不区分)。你改配置前必须确认当前 OS 和 MySQL 启动方式------Docker 容器里改了 my.cnf 却没挂载生效,或者 systemd 启动时绕过了配置文件,都会白忙。修改 lower_case_table_names 的实操前提这个值只能在初始化 MySQL 实例时设置,或在**完全清空数据目录后重启实例**才安全生效。线上库不能热改:设成 1 后再建表 user,旧表 User 仍存在,但 MySQL 会拒绝访问(报错 Table 'db.User' doesn't exist),因为内部元数据已按小写注册,而磁盘上文件名还是大写。必须停服,删掉 datadir 下所有文件(包括 ibdata1、ib_logfile*、数据库子目录)在 my.cnf 的 mysqld 段写明 lower_case_table_names=1用 mysqld --initialize 重建系统表,再启动应用需重新导出/导入数据(mysqldump 输出的 SQL 中表名保持原样,导入时由新规则统一处理)不改配置时怎么避免踩坑开发阶段就统一用小写表名,是最省事的方案。很多 ORM(如 Laravel Eloquent、Django ORM)默认生成小写蛇形命名,但如果你手写 SQL 或用旧脚本,容易混用 UserInfo 和 userinfo。MySQL 5.7+ 在 Linux 上执行 SELECT * FROM UserInfo; 可能成功,但换到 Windows 部署就报错------不是语法错,而是 Table 'db.UserInfo' doesn't exist,因为磁盘上实际是 userinfo.frm。 There's An AI For That 全球领先的 AI 聚合器,收集10,225个AI工具,可用于超过2,548个任务。
相关推荐
兆。7 分钟前
LangChain向量数据库集成指南:面向RAG开发者小小工匠11 分钟前
Redis - 实现分页 + 多条件模糊查询:一套完整可落地的组合方案郑洁文18 分钟前
基于Python的网络入侵检测系统AIMath~24 分钟前
python中的uv命令揭秘弹简特27 分钟前
【零基础学Python】06-Python模块和包、异常处理、文件常用操作念恒1230637 分钟前
Python 面向对象编程核心:对象、实例化、封装与变量作用域流星白龙39 分钟前
【MySQL高阶】13.其他存储引擎薛定谔的悦41 分钟前
光伏-储能-负荷联合预测:给 EMS 装上“预知能力“阿演43 分钟前
DataDjinn v0.1.6 更新:增加在线更新功能,Redis 数据源支持,表格预览和连接体验继续增强数据库小学妹44 分钟前
InnoDB内存架构解密:Buffer Pool与性能优化实战