细说MySQL区分字母大小写

在Linux系统上使用MySQL,MySQL是区分字母大小写的,例如建A表时表名是大写的A,修改A表时脚本里写的a,就会报错表a不存在。在MySQL中,数据库对应数据目录中的目录,数据库中的每个表至少对应数据库目录中的一个文件或多个文件,所以,是否区分大小写是其所在的操作系统决定的。在大多数基于Unix的系统中,MySQL是区分大小写的;而在Windows系统中,MySQL是不区分大小写的。

操作系统中提供了lower_case_table_names参数用于修改这种区分大小写的策略。默认情况下,Linux系统下
lower_case_table_names=0,Windows系统下lower_case_table_names=1,而MacOS下lower_case_table_names=2。0表示使用指定的大小写字母在硬盘上保存表名和数据库名,并且区分字母大小写;1表示表名在硬盘上以小写保存,MySQL将所有表名转换为小写在存储和查找表上,不区分字母大小写;2表示表名和数据库名在硬盘上使用指定的大小写字母进行保存,但MySQL将它们转换为小写在查找表上,不区分字母大小写。

如果想在Linux系统中修改lower_case_table_names的值,让其不区分字母大小写,Google出来的操作步骤大部分都是下面这种:
1.以root登录系统
2.cd /etc/mysql/
3.sudo vim my.cnf
4.在[mysqld]后添加添加lower_case_table_names=1
5.重新启动数据库

然而,有些时候会出现一些特殊情况,例如,打开my.cnf发现里面并没有[mysqld],而是如下的内容:
!includedir /etc/mysql/conf.d/
!includedir /etc/mysql/mysql.conf.d/
这时候,如果直接在里面添加lower_case_table_names=1,则会导致无法和MySQL建立连接的错误产生。正确做法如下:
1.以root登录系统
2.cd /etc/mysql/
3.sudo vim my.cnf
如果发现my.cnf中没有“[mysqld]”,只有如下内容:
!includedir /etc/mysql/conf.d/
!includedir /etc/mysql/mysql.conf.d/
则,cd /etc/mysql/mysql.conf.d/
sudo vim mysqld.cnf
4.在[mysqld]后添加添加lower_case_table_names=1
5.重新启动数据库

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容