MySQL编码问题的经验总结

数据库 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编码编过了,所以,尽管入库,他的机器码肯定就是那样的,不管存放在哪里,不管MySQL(和PHP搭配之***组合)指定为何种编码,他在录入数据的时候,并不会对你的数据进行转换。只要保证你的前端录入使用UTF-8,那么你读取的也是UTF-8。

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

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

解决办法我猜有三种:

 

读取的时候,使用SET NAME将其编码转换,不知道可行不,

读取后使用iconv将其转为GB2312,

 

不用PHPMYADMIN导入,自己写个GB2312的PHP脚本导入即可。

 

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

 

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

【编辑推荐】

  1. MySQL root 密码破解好用方案介绍
  2. MySQLunion 语法代码演示
  3. MySQL ALTER语法的运用
  4. MySQL修改表结构alter 实操
  5. MySQL修改表字段的实际应用代码演示

 

 

责任编辑:佚名 来源: 互联网
相关推荐

2010-05-21 12:43:06

MySQL 5.0存储

2010-11-23 10:34:04

MySQL左连接查询

2009-10-15 09:27:00

2010-05-25 15:51:25

MySQL连接字符串

2010-05-19 14:39:12

MySQL连接字符串

2011-07-21 13:40:17

java

2012-06-25 11:51:31

ibmdw

2010-06-07 15:48:40

Hadoop0.20.

2009-08-19 09:24:43

AJAX引擎经验总结

2009-09-29 16:32:11

OJB Hiberna

2009-09-16 17:13:54

学习Linq

2018-06-07 09:29:34

数据库MySQL慢SQL

2018-12-04 09:07:36

运维问题排查

2010-04-21 14:53:46

Oracle游标

2010-03-25 13:42:14

云计算

2010-03-23 11:39:49

云计算

2013-12-18 15:54:21

2010-06-13 13:44:07

UML学习笔记

2009-09-27 14:53:38

Hibernate S

2010-07-16 09:14:49

Perl模式
点赞
收藏

51CTO技术栈公众号