先贴一下报错信息:
ERROR 1366 (HY000): Incorrect string value: '\xE6\x96\xB0\xE9\x97\xBB...' for column 'title' at row1
处理办法:
我们先用语句看一下MySQL的编码方式
show variables like 'character%';
在我的数据库里看到时这样的:
可以明显的看到 database、server的编码为latinal,下面就通过修改MySQL目录下的my.ini来处理这个问题
如果在MySQL安装目录下没有看到my.ini 可以尝试下面的方法:
修改文件夹选项,选中“显示隐藏的文件、文件夹和驱动器”
然后在C盘的根目录下,会发现隐藏文件夹 “ProgrammaData”,然后根据下面图中的路径依次打开,你可以看到my.ini文件了
用记事本或者notepad++打开my.ini ,现在开始修改:
找到【mysql】
去掉前面的# 号,在等号后加上 utf8 ,如图
然后继续往下找,找到【mysqld】
同样,去掉#号,并在等号后加上utf8
然后保存,重启mysql服务(记得把mysql的服务进程关闭,不能只是关闭命令行窗口然后重新打开)。
我们再用 show variables like 'character%'; 来看看数据库的编码方式
可以看到已经修改成功,我们在回到刚刚的表格重新插入中文数据看看能不能插入。
很不幸,还是报错了,还是和刚才一样的错。
因为,这个数据库是我们在没有修改编码方式的时候建立的,所以它的编码方式没有被改变,这时候我们就要重新新建一个数据库和表,看看能不能插入中文
试验成功。