mysql数据库乱码之保存越南文乱码解决方法
程序员文章站
2024-02-25 19:47:39
我自己测试一下,很多字符变成了 ‘?'。
数据库连接已经是使用了 utf8 字符集:
复制代码 代码如下:define("mysql_encode", "utf8");...
我自己测试一下,很多字符变成了 ‘?'。
数据库连接已经是使用了 utf8 字符集:
复制代码 代码如下:
define("mysql_encode", "utf8");
mysql_query('set names '.mysql_encode,$conn) or die('字符集设置错误'.mysql_error());
搞了大半小时,没有搞定。
insert 的数据都是仍然乱码,突然想,是不是字段不能保存这些越南文。
我看一下数据库字符集,默认都是 gbk,这个对中文是没有问题的,一碰到越南文,就乱码了。
于是,我将可能用到越南文的字段的字符集修改为 utf8,校对修改为:utf8_unicode_ci。(这里一定要具体修改某个字段,修改整个表的字符集,不起作用,字段还是保留着原来的字符集)问题解决。
我的数据库为:php_college_web
表:city_article
用到越南文的字段:title,content
于是执行如下sql:
复制代码 代码如下:
alter table city_article change title title varchar(100) character set utf8 collate utf8_unicode_ci
alter table city_article change content content text character set utf8 collate utf8_unicode_ci