php开源嘛
首页 | English | MySql数据库 | Php编程 | 建站杂烩 | 系统服务器 | 资源共享 | 专题 | 才桀网 | 支持论坛
  当前位置:主页>MySql数据库>文章内容
MySQL数据库中的编码问题的经验总结
来源:收集整理 作者:phpma 发布时间:2007-10-16  

MySQL数据库中的编码问题的经验总结 php开源嘛

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

然后举个使用GB2312和UTF-8的例子。php开源嘛

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

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

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

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

为什么使用PHPMYADMIN导入总是有问题呢?phpphpma.com开源嘛

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

  1. 读取的时候,使用SET NAME将其编码转换,不知道可行不,
  2. 读取后使用iconv将其转为GB2312,
  3. 不用PHPMYADMIN导入,自己写个GB2312的PHP脚本导入即可。

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

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


(阅读次数:
上一篇:PHP生成静态页面、古老的技术新用...   下一篇:网站流量越大不一定就越可靠...
[收藏] [推荐] [评论(0条)] [返回顶部] [打印本页] [关闭窗口]  
用户名: 新注册) 密码: 匿名评论
评论内容:(不能超过250字,需审核后才会公布,请自觉遵守互联网相关政策法规。
 §最新评论
  热点文章
·用于SELECT和WHERE子句的SQL函数
·MySQL索引分析和优化
·MySQL数据库下.frm .MYD .MYI损
·怎么删除MySQL数据库中的重复数
·MySQL数据导入与导出
·MySQL数据库中SQL查询语句精华
·如何优化MySQL数据库性能
·MySQL查询优化之查询优化器
·怎么备份MySQL数据库
·如何导入导出*.sql文件到MySQL数
·MySQL数据导入导出方法与工具介
·MySQL索引分析和优化加速网站访
  相关文章
·MySQL导入导出大量数据的程序实
·MySQL 数据库引擎快速指南...
·MYSQL用户root密码为弱口令的攻
·MySQL数据库中中文模糊检索问题.
·MySQL数据库用调用info()函数...
·MySQL数据库中load data local安
·关于MySQL数据库中的结果字符串.
·1067错误:MySQL 服务无法启动系
·怎样用MySQL和PHP创建XML
·MySQL数据库中Show命令用法
·MYSQL数据库出错代码及出错代号
·Windows环境下MySQL安装的故障诊

关于我们 | 本站声明 | 友情连接 | 诚邀加盟 | 网站地图
版权Power by DedeCms   技术支持QQ =>> 罗江游鱼   Jacking  后台登陆
Copyright @ 2007 公司地址:柳州市东环路268号 邮编:545006 电话:15920389818 桂ICP备07006725号