当前位置:Gxlcms > mysql > mysql数据库乱码的解决方法

mysql数据库乱码的解决方法

时间:2021-07-01 10:21:17 帮助过:18人阅读

做一个包含越南文的网站,用户说在保存包含越南文的文章时,MSYQL乱码了,看下面的解决方法 我自己测试一下,很多字符变成了 ?'。 数据库连接已经是使用了 utf8 字符集: 代码如下:

  1. define(MYSQL_ENCODE, UTF8); mysql_query('SET NAMES '.MYSQL_ENCODE,$con<p></p>
  2. <p></p>
  3. <p></p><p> 做一个包含越南文的网站,用户说在保存包含越南文的文章时,MSYQL乱码了,看下面的解决方法</p>
  4. <p> </p>
  5. <p>我自己测试一下,很多字符变成了 ‘?'。</p>
  6. <p> </p>
  7. <p>数据库连接已经是使用了 utf8 字符集:</p>
  8. <p> </p>
  9. <p> </p>
  10. <p>代码如下:</p>
  11. <p>define("MYSQL_ENCODE", "UTF8");</p>
  12. <p> </p>
  13. <p>mysql_query('SET NAMES '.MYSQL_ENCODE,$conn) or die('字符集设置错误'.mysql_error());</p>
  14. <p> </p>
  15. <p> </p>
  16. <p> </p>
  17. <p>搞了大半小时,没有搞定。</p>
  18. <p> </p>
  19. <p>insert 的数据都是仍然乱码,突然想,是不是字段不能保存这些越南文。</p>
  20. <p> </p>
  21. <p>我看一下数据库字符集,默认都是 gbk,这个对中文是没有问题的,,一碰到越南文,就乱码了。</p>
  22. <p> </p>
  23. <p>于是,我将可能用到越南文的字段的字符集修改为 utf8,校对修改为:utf8_unicode_ci。(这里一定要具体修改某个字段,修改整个表的字符集,不起作用,字段还是保留着原来的字符集)问题解决。</p>
  24. <p> </p>
  25. <p>我的数据库为:php_college_web</p>
  26. <p> </p>
  27. <p>表:city_article</p>
  28. <p> </p>
  29. <p>用到越南文的字段:title,content</p>
  30. <p> </p>
  31. <p>于是执行如下sql:</p>
  32. <p> </p>
  33. <p> </p>
  34. <p>代码如下:</p>
  35. <p>ALTER TABLE city_article CHANGE title title VARCHAR(100) CHARACTER SET utf8 COLLATE utf8_unicode_ci</p>
  36. <p> </p>
  37. <p>ALTER TABLE city_article CHANGE content content text CHARACTER SET utf8 COLLATE utf8_unicode_ci </p>

人气教程排行