MySQL编码问题的实际操作经验浅析

数据库 MySQL
此文章主要向大家描述的是MySQL编码问题的实际操作经验总结,如果你对MySQL编码问题的实际应用与其实际操作经验有兴趣了解的话,以下的文章将会满足你这一愿望。

我们今天要和大家一起分享的是关于MySQL编码问题的实际操作经验总结,我在一些网站上看见过一些关于MySQL编码问题的实际操作方案,但是可行性都特别小,所以今天拿出自己的经验,望大家能有所收获。

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

然后举个使用GB2312和UTF-8的例子。

好,你只要保证你的写着INSERT SQL语句的PHP文件编码为GB2312,恭喜你,你使用写着SELECT SQL语句的GB2312编码的PHP文件读取出来的数据也是GB2312的。
同理,只要你插入数据库的PHP文件是UTF-8编码,那么你录入的就是UTF-8的,读取出来同样使用MySQL编码为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脚本导入即可。总之一句话,你录入的时候采用什么编码,那么你读取的时候他就是什么编码。你想把这种编码显示成另外一种编码,那么你需要使用iconv或者mbstring将其进行MySQL编码转换。

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

关于MySQL编码问题的经验总结

上述的相关内容就是对关于MySQL编码问题的经验总结的描述,希望会给你带来一些帮助在此方面。

【编辑推荐】

  1. MySQL表索引遭到破坏的处理方法
  2. 建立MySQL镜像数据库在linux下很简单
  3. MySQL root 密码忘记的破解
  4. 开发中的MySQL参照完整性简介
  5. Linux上实现MySQL 5的手动安装
责任编辑:佚名 来源: 互联网
相关推荐

2010-05-20 17:40:54

MySQL编码

2010-06-10 09:54:54

MySQL编码

2010-06-12 13:39:33

MySQL操作blob

2010-03-05 15:07:35

Python优化图片

2010-05-18 17:39:13

MySQL alter

2010-05-13 10:09:18

MySQL编码

2009-10-14 10:49:38

综合布线系统

2010-05-26 16:53:21

MySQL show

2010-05-17 11:26:49

MySQL 多级同步

2010-05-25 16:31:23

MySQL配置

2010-03-24 18:00:30

Python中文转换u

2010-05-12 13:45:25

Mysql 复制设置

2009-09-01 14:45:45

C#创建Excel文件

2010-03-12 15:29:19

Pythonexe

2010-05-19 10:37:06

MySQL expla

2010-02-03 16:56:20

C++自定义类

2010-05-24 17:26:22

MySQL添加授权

2010-05-20 15:39:14

MySQL支持中文

2010-05-18 09:40:01

MySQL修改表字段

2010-06-01 15:54:46

MySQL-pytho
点赞
收藏

51CTO技术栈公众号