如何设置MySQL使其不自动小写(mysql 不自动小写)

如何设置MySQL使其不自动小写?

MySQL是一种流行的关系型数据库管理系统,它支持许多功能和选项,可以根据需要进行配置。其中一个常见的问题是MySQL自动将表名、列名和数据库名转换为小写,这会使查询和操作变得更加困难和繁琐。幸运的是,MySQL提供了一些选项来解决这个问题。

在MySQL中,控制标识符(即表名、列名和数据库名)大小写的选项是lower_case_table_names参数。默认情况下,它被设置为1,表示MySQL将标识符转换为小写。如果将此参数更改为0,则MySQL将保留标识符的大小写。但是,需要注意的是,这种配置适用于仅在Unix或Linux操作系统上的MySQL安装和仅在大小写敏感的文件系统上运行的实例。

要设置lower_case_table_names参数,请参考以下步骤:

1.打开MySQL配置文件my.cnf或my.ini,该文件通常在MySQL安装目录的根目录下或在/etc/mysql/目录下。

2.找到[mysqld]部分,如果该部分不存在,请在文件末尾添加该部分。

3.在[mysqld]部分中添加或编辑lower_case_table_names选项,将其设置为0,如下所示:

[mysqld]

lower_case_table_names=0

4.保存并关闭my.cnf或my.ini文件。

5.重新启动MySQL服务器,以使更改生效。

在某些情况下,您可能需要使用大小写敏感的文件系统来运行MySQL实例,例如使用Windows操作系统时。在这种情况下,您需要使用以下方法来完全禁用MySQL大小写转换:

1.打开MySQL配置文件my.cnf或my.ini,该文件通常在MySQL安装目录的根目录下或在/etc/mysql/目录下。

2.找到[mysqld]部分,如果该部分不存在,请在文件末尾添加该部分。

3.在[mysqld]部分中添加或编辑以下三个选项:

[mysqld]

lower_case_table_names=2

datadir_case_sensitive=1

innodb_file_per_table=1

lower_case_table_names选项设置为2,表示完全禁用MySQL大小写转换。datadir_case_sensitive选项设置为1,表示数据目录(通常位于/var/lib/mysql/)使用大小写敏感的文件系统。innodb_file_per_table选项设置为1,表示每个InnoDB表将有自己的数据文件。

4.保存并关闭my.cnf或my.ini文件。

5.重新启动MySQL服务器,以使更改生效。

现在,您已经成功地设置MySQL不会自动将标识符转换为小写,而是保留其原始大小写。这将使查询和操作变得更加方便和易于管理。


【AD】美国洛杉矶/香港/日本VPS推荐,回程电信CN2 GIA线路,延迟低、稳定性高、免费备份_搬瓦工

【AD】炭云:36元/年/1GB内存/20GB SSD空间/500GB流量/5Gbps端口/KVM/香港/国际线路LUMEN