@[toc]
原因
mysql不能插入中文字符是因为默认使用的字符集是latin1,latin1是拉丁码表的别名,ISO8859-1:拉丁码表。欧洲码表 ,用一个字节的8位表示,MySQL是欧洲人发明的,所以他们的默认字符集是这个
解决办法
修改mysql的数据目录下的my.ini配置文件
数据目录在之前安装的时候定的目录的下面一个:见文章MySQL_01:MySQL的安装、下载、卸载、配置、登录
找到 [mysql] 大概在63行左右,在其下添加
default-character-set=utf8
找到 [mysqld] 大概在76行左右,在其下添加
character-set-server=utf8 collation-server=utf8_general_ci
注意:建议修改配置文件使用notepad++等高级文本编辑器,使用记事本等软件打开修改后可能会 导致文件编码修改为“含BOM头”的编码,从而服务重启失败。
- 重启服务:任务管理器找到对呀的MySQL服务,重启即可
查看编码命令:(显式的看见为utf8就证明修改成功)
show variables like 'character_%'; show variables like 'collation_%';
注意:如果之前建了数据库,然后又发现不能使用中文,又来修改了min文件后,再去添加元素发现仍然行不通,是因为数据库建的时候本身就使用了拉丁码表,需要重新去建库
MySQL8.0中
在MySQL 8.0版本之前,默认字符集为latin1,utf8字符集指向的是utf8mb3。网站开发人员在数据库设计 的时候往往会将编码修改为utf8字符集。如果遗忘修改默认的编码,就会出现乱码的问题。从MySQL 8.0 开始,数据库的默认编码改为 utf8mb4 ,从而避免了上述的乱码问题。