我们今天要向大家讨论的是mysql编码问题的实际操作经验,我是一个mysql数据库的热捧者,对mysql数据库相关的实际应用很是感兴趣,以下的文章就是主要介绍mysql编码问题的经验大总结。 以下所描述无理论依据,纯属经验谈。 mysql(和php搭配之最佳组合)使用4.1
我们今天要向大家讨论的是mysql编码问题的实际操作经验,我是一个mysql数据库的热捧者,对mysql数据库相关的实际应用很是感兴趣,以下的文章就是主要介绍mysql编码问题的经验大总结。
以下所描述无理论依据,纯属经验谈。
mysql(和php搭配之最佳组合)使用4.1以上版本,管他是什么字符集,一律使用默认。不用去设置mysql(和php搭配之最佳组合)。
然后举个使用gb2312和utf-8的例子。
好,你只要保证你的写着insert sql语句的php文件mysql编码为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将其mysql编码转换,不知道可行不,
读取后使用iconv将其转为gb2312,
不用phpmyadmin导入,自己写个gb2312的php脚本导入即可。
总之一句话,你录入的时候采用什么mysql编码,那么你读取的时候他就是什么编码。你想把这种编码显示成另外一种编码,那么你需要使用iconv或者mbstring将其进行编码转换。
以上仅为个人实际经验,没时间研究理论。欢迎大家探讨或者有错误请指正。