细说MySQL区分字母大小写

Original 2016-11-02 14:03:05 836
abstract:在Linux系统上使用MySQL,MySQL是区分字母大小写的,例如建A表时表名是大写的A,修改A表时脚本里写的a,就会报错表a不存在。在MySQL中,数据库对应数据目录中的目录,数据库中的每个表至少对应数据库目录中的一个文件或多个文件,所以,是否区分大小写是其所在的操作系统决定的。在大多数基于Unix的系统中,MySQL是区分大小写的;而在Windows系统中,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.重新启动数据库


Release Notes

Popular Entries