细说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.重新启动数据库

0?wx_fmt=png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值