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进行MySQL编码转换,将str转为GB2312入库,读取也一样,使用iconv转为UTF-8显示。

你的前端页面使用什么编码,那么你那些字符串已经被该种编码编过了,所以,尽管入库,他的机器码肯定就是那样的,不管存放在哪里,不管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将其进行编码转换。

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

 MySQL编码问题的经验总结


以上的相关内容就是对关于MySQL编码问题的经验总结的介绍,望你能有所收获。

【编辑推荐】

  1. 实现MySQL数据库引擎的快速指导
  2. MySQL初学者的必备3要素
  3. MySQL维护与实际应用的设计笔记简介
  4. 实现MySQL双机热备的实际操作步骤
  5. MySQL root密码重置的三步骤
责任编辑:佚名 来源: 互联网
相关推荐

2010-08-24 10:11:02

虚拟化部署

2010-06-11 10:30:38

MySQL编码

2011-06-28 09:39:31

Qt

2010-05-19 17:24:55

MySQL编码

2010-03-26 09:42:22

CentOS MAKE

2010-05-20 17:40:54

MySQL编码

2010-05-13 16:51:34

MySQL4.1

2010-06-10 09:54:54

MySQL编码

2009-06-12 12:37:38

Java软件

2010-05-13 10:27:24

MySQL数据库

2010-06-04 17:58:09

MySQL远程连接

2017-01-05 18:43:58

闰秒Linux服务器

2010-06-04 15:57:03

PHP+MYSQL

2024-09-20 07:41:41

性能信息收集架构

2024-11-11 08:03:38

2010-06-13 11:20:31

win7 Ubuntu

2020-09-23 17:23:18

人工智能技术数据

2013-09-11 09:29:01

2009-07-06 18:53:52

ESXESX主机VMware

2020-03-31 16:16:58

DNS劫持https证书
点赞
收藏

51CTO技术栈公众号