关于MySQL编码问题的经验总结
来源:互联网 发布:澳门赌场网络平台 编辑:程序博客网 时间:2024/05/20 14:20
以下所描述无理论依据,纯属经验谈。
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文件来读取,当然一堆乱。
解决办法我猜有三种:
- 读取的时候,使用SET NAME将其编码转换,不知道可行不,
- 读取后使用iconv将其转为GB2312,
- 不用PHPMYADMIN导入,自己写个GB2312的PHP脚本导入即可。
总之一句话,你录入的时候采用什么编码,那么你读取的时候他就是什么编码。你想把这种编码显示成另外一种编码,那么你需要使用iconv或者mbstring将其进行编码转换。
以上仅为个人实际经验,没时间研究理论。欢迎大家探讨或者有错误请指正。
转:http://www.blueidea.com/tech/program/2007/4910.asp
- 关于MySQL编码问题的经验总结
- 关于MySQL编码问题的经验总结
- 关于MySQL编码问题的经验总结
- 关于mysql的编码问题
- 关于mysql编码的问题
- 关于编码盒直播的经验总结
- 关于mysql编码问题
- 关于mysql的安装以及编码问题
- 关于mysql编码问题的一点理解
- 关于Linux下Mysql的编码问题
- mysql中关于数据的编码问题
- 关于mysql数据库的utf8编码问题
- 关于mysql的1067错误经验总结
- MYSQL中关于编码问题
- 关于MySQL编码问题解析
- 【经验总结】关于文件复制的一个问题
- 非常好的一篇关于MYSQL编码问题的文章
- 关于编码的问题
- 4+1视图模型概况
- 关于数据库日志问题!
- jsp中文传值乱码问题
- 电信重组又起,对移动软件供应商与SP的影响有哪些!思考:如何从3G网络中找寻我们程序员的价值..
- javascript IE7下的关闭文件问题
- 关于MySQL编码问题的经验总结
- Java学习之回调
- Dom4j操作xml
- 用汇编修改dos版三国英杰传支持键盘操作
- BizTalk是什么,能作什么?这个问题,以前我也搜过,不过还是一头雾水.现在知道了,它就是一个翻译官
- ibatis中属性读取的一个知识点
- SAP实施工作随想
- Microsoft .Net Remoting系列专题之一:.Net Remoting基础篇
- 取得汉字字符的拼音的首字母