在Linux系统中部署的MySQL数据库,默认情况下表名是区分大小写的,这个行为由MySQL的系统变量lower_case_table_names控制,不同的取值对应不同的表名处理规则,同时和系统文件系统的特性也有直接关联。

lower_case_table_names变量说明
该变量是MySQL中控制表名和数据库名大小写敏感性的核心参数,支持三个取值,不同取值的含义如下:
| 取值 | 含义 | 适用场景 |
|---|---|---|
| 0 | 表名按指定大小写存储,比较时区分大小写 | Linux系统默认取值,适合严格区分大小写的环境 |
| 1 | 表名以小写形式存储到磁盘,比较时不区分大小写 | 需要跨系统兼容的场景,比如同时有Windows和Linux环境 |
| 2 | 表名按指定大小写存储,但比较时转为小写匹配 | Mac OS等文件系统不区分大小写的系统 |
不同取值的实际表现
取值为0时的表现
当lower_case_table_names设置为0时,创建表时指定的表名会原样存储,查询时也必须严格匹配大小写。我们可以通过以下示例验证:
-- 查看当前变量取值 SHOW VARIABLES LIKE 'lower_case_table_names'; -- 创建两个表名仅大小写不同的表 CREATE TABLE TestTable (id INT); CREATE TABLE testtable (id INT); -- 查询时大小写不匹配会报错 SELECT * FROM testtable; -- 如果创建的表是TestTable,该查询会提示表不存在
取值为1时的表现
当取值为1时,无论创建表时指定什么大小写的表名,实际存储到磁盘的都是小写形式,查询时输入任意大小写的表名都会被转为小写匹配:
-- 此时创建表 CREATE TABLE TestTable (id INT); -- 以下两个查询都会正常执行,匹配到同一个表 SELECT * FROM TestTable; SELECT * FROM testtable; SELECT * FROM TESTTABLE;
如何修改该变量配置
修改lower_case_table_names需要注意,该变量是只读变量,无法在MySQL运行时动态修改,必须修改配置文件后重启服务生效,且修改前需要处理好已有的表名,避免数据丢失。
修改步骤
- 首先备份所有数据库,避免修改过程中数据损坏
- 停止MySQL服务,不同系统命令不同,比如Ubuntu使用
systemctl stop mysql - 编辑MySQL配置文件,一般是
/etc/mysql/my.cnf或者/etc/my.cnf,在[mysqld]section下添加或修改配置:
[mysqld] lower_case_table_names=1
- 保存配置文件后启动MySQL服务,再次查询变量确认修改生效
注意事项
如果在已经有表的情况下修改该变量,需要提前处理表名:如果要从0改为1,需要先把所有表名改为小写,否则可能因为表名大小写不匹配导致表无法访问;如果要从1改为0,需要确认所有查询语句中的表名和实际存储的小写表名一致。另外Windows系统下该变量默认是1,从Windows迁移到Linux时如果遇到表不存在的问题,优先检查该变量的配置是否一致。
MySQLLinux表名大小写lower_case_table_names修改时间:2026-07-02 09:48:18