关于MySQL编码问题的经验总结

作者:深空 来源:蓝色理想 时间:2007-08-23 16:10:00 

以下所描述无理论依据,纯属经验谈

MySQL使用4.1以上版本,管他是什么字符集,一律使用默认。不用去设置MySQL。

然后举个使用GB2312和UTF-8的例子。

好,你只要保证你的写着Insert SQL语句的PHP文件编码为GB2312,恭喜你,你使用写着Select SQL语句的GB2312编码的PHP文件读取出来的数据也是GB2312的。
同理,只要你插入数据库的PHP文件是UTF-8编码,那么你录入的就是UTF-8的,读取出来同样使用编码为UTF-8的读取。

如果我录入为GB2312,显示要使用UTF-8怎么办?

如果你的所有PHP文件为UTF-8编码,那么你在Insert的时候,就必须使用iconv进行编码转换,将str转为GB2312入库,读取也一样,使用iconv转为UTF-8显示。

你的前端页面使用什么编码,那么你那些字符串已经被该种编码编过了,所以,尽管入库,他的机器码肯定就是那样的,不管存放在哪里,不管MYSQL指定为何种编码,他在录入数据的时候,并不会对你的数据进行转换。只要保证你的前端录入使用UTF-8,那么你读取的也是UTF-8。

为什么使用PHPMYADMIN导入总是有问题呢?

我没有研究过PHPMYADMIN的工作原理,但是他的PHP文件都是UTF-8编码的,也就是这样导入数据都是UTF-8的,你采用GB2312的PHP文件来读取,当然一堆乱。
解决办法我猜有三种:

  1. 读取的时候,使用SET NAME将其编码转换,不知道可行不,

  2. 读取后使用iconv将其转为GB2312,

  3. 不用PHPMYADMIN导入,自己写个GB2312的PHP脚本导入即可。

总之一句话,你录入的时候采用什么编码,那么你读取的时候他就是什么编码。你想把这种编码显示成另外一种编码,那么你需要使用iconv或者mbstring将其进行编码转换。

以上仅为个人实际经验,没时间研究理论。欢迎大家探讨或者有错误请指正。

标签:mysql,编码
0
投稿

猜你喜欢

  • sqlserver合并DataTable并排除重复数据的通用方法分享

    2012-01-05 18:59:56
  • YUI 学习笔记:Event

    2009-02-21 11:15:00
  • 全新感受Oracle 9i

    2010-07-16 13:32:00
  • javascript new fun的执行过程

    2010-08-05 21:23:00
  • asp利用Split函数进行多关键字检索

    2011-03-16 11:10:00
  • 三种不同方式连接MySQL数据库的方法及示例

    2010-06-11 13:37:00
  • 基于网格的网页设计概念及实际应用案例

    2010-03-30 14:59:00
  • 浅论网站用户粘性的提高和增强

    2008-05-15 07:14:00
  • 使用css2.1实现多重背景、多重边框效果[译]

    2010-08-23 16:32:00
  • 针对google Chrome的 CSS hacks

    2009-11-30 12:45:00
  • asp 去掉html中的table正则代码函数

    2011-04-06 10:48:00
  • block 和 inline 答案揭晓~ 另付一则,关于 word-break

    2009-12-08 13:06:00
  • 用CSS制作兼容多浏览量器的隐藏菜单

    2007-08-30 09:05:00
  • FileUpload上传图片预览不变形

    2010-08-05 21:25:00
  • asp如何实现网上考试功能?

    2010-05-24 18:32:00
  • 网页设计者应当注意九大要点

    2007-08-10 13:30:00
  • Firefox 3.5 新增加的支持(整理)

    2009-08-01 12:51:00
  • mysql Load Data InFile 的用法

    2009-09-06 12:08:00
  • 重温Javascript继承机制

    2011-07-04 12:17:23
  • 善用用户反馈——浅谈用户反馈数据的处理

    2010-07-09 16:58:00
  • asp之家 网络编程 m.aspxhome.com