维修网点 | 网站地图 | 加入收藏 | 设为首页 | 联系站长 |
本站公告: (请经常关注我站公告,您将有意想不到的收获!) 欢迎光临北京速帮电器维修网,这里是京城最专业的电器维修企业网,希望它可以带给你机器恢复生机的希望![速帮电器维修网  2008年7月9日]   您好,今天是:
当前位置:北京速帮电器维修网 >> 网络工程 >> 网站数据库开发 >> 浏览文章
关于MySQL编码问题的经验总结!
时间: 2008年10月21日 来源:互联网 作者: 未知 浏览次数:

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

MySQL(和PHP搭配之最佳组合)使用4.1以上版本,管他是什么字符集,一律使用默认。不用去设置MySQL(和PHP搭配之最佳组合)。

然后举个使用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(和PHP搭配之最佳组合)指定为何种编码,他在录入数据的时候,并不会对你的数据进行转换。只要保证你的前端录入使用UTF-8,那么你读取的也是UTF-8。

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

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

读取的时候,使用SET NAME将其编码转换,不知道可行不,
读取后使用iconv将其转为GB2312,
不用PHPMYADMIN导入,自己写个GB2312的PHP脚本导入即可。
总之一句话,你录入的时候采用什么编码,那么你读取的时候他就是什么编码。你想把这种编码显示成另外一种编码,那么你需要使用iconv或者mbstring将其进行编码转换。

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

发表评论】【告诉好友】【打印此文】【收藏此文】【关闭窗口
上一篇:如何修复损坏的MySQL数据表 下一篇文章:MySQL 中修改密码及访问限制设置详解
我也说两句

24小时热门信息 发表文章
特别推荐
最新更新
购物须知 | 付款方式 | 关于速帮 | 联系速帮 | 友情链接
Copyright 1998-2008 Powered by Bjlxjw.COM,北京速帮维修网 All Rights Reserved.
服务电话:010-60118386 86802160 传真:010-64621509 E-Mail:bjwxzx@126.com
技术支持及报修手机:13146594250 维修咨询服务QQ:136310508 京ICP备案:05032683号