mysql表名大小写敏感问题如何处理_Lower Case Table Names设置

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个任务。

相关推荐
顾林海13 分钟前
Agent入门阶段-编程基础-Python:流程控制
python·agent·ai编程
呱呱复呱呱3 小时前
Django CBV 源码解读:一个请求是怎么找到你的 get() 方法的
python·django
Nturmoils4 小时前
订单列表慢查询,先看 WHERE、ORDER BY 和 LIMIT
数据库
曲幽8 小时前
刚部署的 LibreTranslate 频频翻车?我掏出了 20 年前的 StarDict 词典,用 FastAPI 搭了个本地词典翻译 API
python·fastapi·web·translate·goldendict·libretranslate·stardict·pystardict
渣波8 小时前
拒绝 SQL 焦虑!手把手带你用 NestJS + Prisma + DTO 写出“防弹”级后端代码
javascript·数据库·后端
荣码8 小时前
用Streamlit给AI应用套个界面,10行代码出Web页面
java·python
兵慌码乱17 小时前
基于Python+PyQt5+SQLite的药房管理系统实现:事务一致性与界面解耦全流程解析
python·sqlite·信号与槽·pyqt5·数据库设计·桌面应用开发·事务处理
金銀銅鐵19 小时前
[Python] 体验用欧几里得算法计算最大公约数的过程
python·数学
FreakStudio1 天前
W55MH32L-EVB 上手测评:硬件 TCP/IP 加持的以太网单片机,MicroPython 零门槛开发
python·单片机·嵌入式·大学生·面向对象·并行计算·电子diy·电子计算机
用户0332126663671 天前
使用 Python 从零创建 Word 文档
python