载入中…
 | 网站首页 | 新知评论 | 网站运营 | 技术文档 | 源码下载 | 模板素材 | 网页特效 | 酷站推荐 | 供求信息 | 论坛交流 | 软件下载 | 
您现在的位置: 网页吧 > 技术文档 > 数据库 > MySQL > 正文
关于MySQL编码问题的经验总结
作者:未知    技术文章来源:wangyeba.com    点击数:    更新时间:2007-8-24  收藏此文:收藏此文到QQ书签

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

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将其进行编码转换。

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

发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
  • 上一篇技术文章:

  • 下一篇技术文章:
  • 读 者 评 论
    姓 名: * 游客填写  ·注册用户 ·忘记密码
    主 页:
    评 分: 1分 2分 3分 4分 5分
    评论内容:
  • 请遵守《互联网电子公告服务管理规定》及中华人民共和国其他各项有关法律法规。
  • 严禁发表危害国家安全、损害国家利益、破坏民族团结、破坏国家宗教政策、破坏社会稳定、侮辱、诽谤、教唆、淫秽等内容的评论 。
  • 用户需对自己在使用本站服务过程中的行为承担法律责任(直接或间接导致的)。
  • 本站管理员有权保留或删除评论内容。
  • 评论内容只代表网友个人观点,与本网站立场无关。
  •        Copyright © 2005-2006 wangyeba.com . All rights reserved. 业务QQ:373985540
            带宽支持:南京你来我往信息技术有限公司 技术支持: 湖南新思维网络
         信产部备案:湘05010653