以下的文章主要描述的是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错误 2013
数据过大的问题,你把需要的表都优化维护一下。 还不行的话你就把ECT文件夹下的文件里的数给+大。
使用utf-8格式的时候怎么在mysql中插入中文
A. 字符编码:“使用命令行方式登陆到MySQL服务器, 建立一个数据库,数据库编码设为UTF-8。此时,如果直接在命令行窗口使用insert语句插入中文,就遇到类似 ERROR 1406 ():把其中 的STRICT_TRANS_tableS,去掉,或者把sql- mode=STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION注释掉,然 后重启mysql就ok了”
从Mysql 里面导出来的数据怎么是乱码?
这是编码不同造成的,要保证下面三处的编码相同才行 以编码为 Utf-8为例:1.在创建网页时 首选项里面 要用 charset=utf-8;2.在建表的时候设置编码类型整理编码 为 utf-8;3.以PHP为例 在数据库连接语句处 要加一行mysql_query(SET NAMES utf-8) 进行数据格式化;比如:$db_host=localhost;$db_user=root;$db_password=password;$db_name=test;$link=mysql_Connect($db_host,$db_user,$db_password);mysql_query(SET NAMES utf-8,$link);// 这句是 防乱码 重点$db=mysql_select_db($db_name,$link);只要保证做到上面三条 就不会出现中文乱码了 编码也可以选其它的 只要三处编码相同就行;Good luck~~
发表评论