最近在windows上新安装的MySQL数据库不能插入中文字段,发现这个问题是由于字符集不匹配导致的,为此需要修改mysql的字符集配置,将字符集修改为UTF-8就可以解决这个问题。

连接MySQL

  在DOS命令窗口输入命令:mysql -hlocalhost -uroot -p,如果配置了数据库密码输入密码即可。前述命令参数:

    -h  服务器名,localhost表示本地;

    -u  数据库用户名,root是mysql默认用户名;

    -p  密码,如果设置了密码,可直接在 -p 后输入,如:-proot,如果没有设置密码,显示Enter password时,直接回车即可。

  连接成功后显示如下:



C:\Users\samsung>mysql -hlocalhost -uroot -p
Enter password: ****
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 2
Server version: 5.7.26-log MySQL Community Server (GPL)

Copyright (c) 2000, 2019, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql>



 

查看MySQL当前字符集

  使用命令 show variables like 'character_set_%'; 查看MySQL当前字符集:



mysql> show variables like 'character_set_%';
+--------------------------+---------------------------------------------------------+
| Variable_name            | Value                                                   |
+--------------------------+---------------------------------------------------------+
| character_set_client     | gb2312                                                  |
| character_set_connection | gb2312                                                  |
| character_set_database   | latin1                                                  |
| character_set_filesystem | binary                                                  |
| character_set_results    | gb2312                                                  |
| character_set_server     | latin1                                                  |
| character_set_system     | utf8                                                    |
| character_sets_dir       | C:\Program Files\MySQL\MySQL Server 5.7\share\charsets\ |
+--------------------------+---------------------------------------------------------+
8 rows in set, 1 warning (0.01 sec)



 

修改MySQL数据库字符集

  MySQL的配置文件是my.ini文件,修改MySQL安装目录下的my.ini文件的配置项:

    default-character-set=utf8

    character-set-server=utf8

  MySQL安装目录中可能没有my.ini文件,因此需要新建一个my.ini文件或者从路径 C:\ProgramData\MySQL\MySQL Server 5.7 拷贝一个my.ini文件到安装目录,之后对上述两个配置项进行修改即可。

  修改后,我们再看看MySQL的字符集:



mysql> show variables like 'character_set_%';
+--------------------------+---------------------------------------------------------+
| Variable_name            | Value                                                   |
+--------------------------+---------------------------------------------------------+
| character_set_client     | utf8                                                    |
| character_set_connection | utf8                                                    |
| character_set_database   | latin1                                                  |
| character_set_filesystem | binary                                                  |
| character_set_results    | utf8                                                    |
| character_set_server     | latin1                                                  |
| character_set_system     | utf8                                                    |
| character_sets_dir       | C:\Program Files\MySQL\MySQL Server 5.7\share\charsets\ |
+--------------------------+---------------------------------------------------------+
8 rows in set, 1 warning (0.01 sec)



  可以看到,字符集已经修改成功。配置文件修改后需要重启MySQL服务。

 

重启MySql服务

  如果MySql服务已经启动了需要先停止,然后再启动,启动、停止MySql服务的命令如下:

    启动MySQL服务 net start mysql
    停止MySQL服务 net stop mysql

  上述命令中的mysql是服务名,MySql实际服务名是字符串"mysql"加版本号,比如我安装的版本为:MySQL Server 5.7,因此服务名为mysql57。

  停止MySql服务:



C:\Users\samsung>net stop mysql57
MySQL57 服务正在停止.
MySQL57 服务已成功停止。



  启动MySql服务:



C:\Users\samsung>net start mysql57
MySQL57 服务正在启动 .
MySQL57 服务已经启动成功。



 

验证

  字符编码已经修改好了,MySql服务也已经重启了,应该可以插入中文了吧。遗憾的是,测试时插入中文数据还是会报错,重新创建一次数据库和数据表,这样就可以成功插入中文字段了。有人说可以直接把数据库和数据表编码方式修改为utf-8,用这两个命令:

alter database databasename character set utf8;
  alter table tablename convert to character set utf8;

  由于我是新创建的数据库和数据表,就删掉重新创建了,修改数据库和数据表编码的方法没有试过,是否管用就不得而知了。如果数据库或数据表不能删除,可以试下这种方法。