MySQL因大小写敏感

    技术2025-12-31  3

    MySQL因大小写敏感

    阿里巴巴Java开发手册,在MySql建表规约里有看到:

    【强制】表名、字段名必须使用小写字母或数字 , 禁止出现数字开头,禁止两个下划线中间只 出现数字。数据库字段名的修改代价很大,因为无法进行预发布,所以字段名称需要慎重考虑。

    说明: MySQL 在 Windows 下不区分大小写,但在 Linux 下默认是区分大小写。

    因此,数据库名、 表名、字段名,都不允许出现任何大写字母,避免节外生枝。

    正例: aliyun _ admin , rdc _ config , level 3_ name

    反例: AliyunAdmin , rdcConfig , level 3 name

    在本机上开发和测试过程中一直没有问题,但是部署到Linux服务器上后,发现有报错,日志信息大概是:

    MySQLSyntaxErrorException: Table ‘kytu.tb_sutyHo’ doesn’t exist

    ①数据库查看这个表在不在,一看还真在,数据库中显示的tb_sutyho ,不过h是小写;

    ②查看代码发现代码中还真把表名写成tb_sutyHo ,就一个h写成大写H了。 修改OK

    验证 MySQL 在 Windows 下不区分大小写,但在 Linux 下默认是区分大小写 在本机Window环境查看如下:

    mysql> show variables like '%case%'; +------------------------+-------+ | Variable_name | Value | +------------------------+-------+ | lower_case_file_system | ON | | lower_case_table_names | 1 | +------------------------+-------+

    在Linux服务器查看如下:

    mysql> show variables like '%case%'; +------------------------+-------+ | Variable_name | Value | +------------------------+-------+ | lower_case_file_system | OFF | | lower_case_table_names | 0 | +------------------------+-------+

    此变量描述数据目录所在的文件系统上文件名的区分大小写。 OFF表示文件名区分大小写,ON表示它们不区分大小写。此变量是只读的,因为它反映了文件系统属性并设置它对文件系统没有影响。

    lower_case_table_names 该参数为静态,可设置为0、1、2。

    0 --大小写敏感。(Unix,Linux默认)

    使用CREATE TABLE或CREATE DATABASE语句指定的大小写字母在硬盘上保存表名和数据库名。名称比较对大小写敏感。在大小写不敏感的操作系统如windows或Mac OS x上我们不能将该参数设为0,如果在大小写不敏感的文件系统上将–lowercase-table-names强制设为0,并且使用不同的大小写访问MyISAM表名,可能会导致索引破坏。

    1 --大小写不敏感。(Windows默认) 表名在硬盘上以小写保存,名称比较对大小写不敏感。MySQL将所有表名转换为小写在存储和查找表上。该行为也适合数据库名和表的别名。该值为Windows的默认值。

    2 --大小写不敏感(OS X默认) 表名和数据库名在硬盘上使用CREATE TABLE或CREATE DATABASE语句指定的大小写字母进行保存,但MySQL将它们转换为小写在查找表上。名称比较对大小写不敏感,即按照大小写来保存,按照小写来比较。注释:只在对大小写不敏感的文件系统上适用! innodb表名用小写保存。

    On Windows the default value is 1. On macOS, the default value is 2. On Linux, a value of 2 is not supported; the server forces the value to 0 instead.

    在Windows上,默认值为1。在macOS上,默认值为2。在Linux上不支持值2;服务器强制该值为0。

    并且官网也提示说:如果在数据目录驻留在不区分大小写的文件系统(例如Windows或macOS)上的系统上运行MySQL,则不应将lower_case_table_names设置为0。

    我自己在我的window10环境尝试设置lower_case_table_names为0的时候,MySQL的服务怎么也启动不能,启动服务报错。windows系统对大小写不敏感,见下图:

    注: 如果要修改lower_case_table_names这个值,windows下修改my.ini ,Linux下修改my.cnf配置文件,需要重启服务,具体操作可以自行上网找资料。

    02 注意事项 修改lower_case_table_names导致的常见不良隐患:

    如果在lower_case_table_names=0时,创建了含有大写字母的库表,改为lower_case_table_names=1后,则会无法被查到。 首先设置lower_case_table_names=0

    CREATE TABLE `Student` ( `id` int(11) unsigned NOT NULL AUTO_INCREMENT, `name` varchar(25) NOT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; show tables; +----------------+ | Tables_in_aflyun | +----------------+ | Student | +----------------+

    再设置lower_case_table_names=1,执行查询,不管表名是大写还是小写,都提示表不存在。

    mysql> select * from Student; 1146 - Table 'aflyun.Student' doesn't exist mysql> select * from student; 1146 - Table 'aflyun.student' doesn't exist

    解决方法:

    如果要将默认的lower_case_tables_name为0设置成1,需先将已经存在的库表名转换为小写。

    针对仅表名存在大写字母的情况:

    ①、lower_case_tables_name=0时,执行rename table成小写。 ②、设置lower_case_tables_name=1,重启生效。

    针对库名存在大写字母的情况:

    ①、lower_case_tables_name=0时,使用mysqldump导出,并删除老的数据库。 ②、设置lower_case_tables_name=1,重启生效。 ③、导入数据至实例,此时包含大写字母的库名已转换为小写。

    总结

    我们在开发时,应该按大小写敏感的原则去开发,这样可以使开发的程序兼容不同的操作系统。控制代码大小写敏感,提高代码的兼容和严谨。

    Processed: 0.014, SQL: 9