Windows下mysql 5.7 设置区分大小写(敏感),设置默认编码 utf8m

1. 前言

mysql 5.7 默认是不区分大小写的,如果需要进行区分大小写的设置,需要进行相关的配置,本文将介绍如何在Windows下设置mysql 5.7进行大小写敏感的配置,同时也会讲解如何设置默认编码为utf8m。

2. 区分大小写配置

默认情况下,mysql 5.7是不区分大小写的。因此,如果需要进行区分大小写的配置,需要打开mysql配置文件my.ini,一般位于mysql安装目录下。

在my.ini配置文件中找到[mysqld],在其下面添加一行代码:`lower_case_table_names=2`。

在Windows系统下,如果要进行大小写敏感的配置,需要将lower_case_table_names的值设置为2。

附:lower_case_table_names的取值范围:

0:代表大小写敏感,表名存储在操作系统的本地大小写形式(默认值)。

1:代表大小写不敏感,表名存储在操作系统的本地大写形式。

2:代表大小写不敏感,表名以小写形式存储,但比较时以不区分大小写方式进行。

修改完后需要对mysql服务进行重启。

2.1 注意事项

修改lower_case_table_names为2后,有一些需要注意的地方:

表名、数据库名和列名区分大小写,例如'mydb'和'MYDB'是不同的。

如果有存储在MyISAM表引擎之外的文件名,无论其大小写形式如何,都需要使用区分大小写的文件系统。

不要将lower_case_table_names的值从0或1更改为2,因为可能会导致数据损坏。

3. 设置默认编码utf8m

如果需要使用mysql 5.7在Windows下进行中文存储,则需要将默认编码设置为utf8m。

同样是在my.ini配置文件中的[mysqld]下,添加以下几行代码来进行编码配置:

collation_server=utf8mb4_unicode_ci

init_connect='SET NAMES utf8mb4'

character-set-server=utf8mb4

修改完后需要对mysql服务进行重启。

3.1 注意事项

对于Windows系统下mysql 5.7进行编码设置时,需要注意以下几点:

要使用utf8mb4编码,而非utf8编码,因为utf8只支持3个字节编码,不能支持某些特殊字符的存储。

在设置时要去除已经设置的character_set_server和collation_server,如果没有去除,对新建的数据库会生效,对已经存在的数据库和表不生效。

在操作数据库前需要执行SET NAMES utf8mb4设置连接的编码,否则可能会出现中文乱码的情况。

4. 总结

通过本文的介绍,我们了解到如何在Windows下进行mysql 5.7的大小写敏感配置和默认编码设置。在实际开发中,这些配置将有助于我们更好地操作和存储中文数据。

数据库标签