我们今天要向大家讨论的是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(和PHP搭配之更佳组合)指定为何种编码,他在录入数据的时候,并不会对你的数据进行转换。只要保证你的前端录入使用UTF-8,那么你读取的也是UTF-8。
为什么使用PHPMYADMIN导入总是有问题呢?
我没有研究过PHPMYADMIN的工作原理,但是他的PHP文件都是UTF-8编码的,也就是这样导入数据都是UTF-8的,你采用GB2312的PHP文件来读取,当然一堆乱。
解决办法我猜有三种:
读取的时候,使用SET NAME将其MySQL编码转换,不知道可行不,
读取后使用iconv将其转为GB2312,
不用PHPMYADMIN导入,自己写个GB2312的PHP脚本导入即可。
总之一句话,你录入的时候采用什么MySQL编码,那么你读取的时候他就是什么编码。你想把这种编码显示成另外一种编码,那么你需要使用iconv或者mbstring将其进行编码转换。
以上仅为个人实际经验,没时间研究理论。欢迎大家探讨或者有错误请指正。
扫描二维码推送至手机访问。
版权声明:本文由2345好导航站长资讯发布,如需转载请注明出处。
假如碰到电脑里的文件夹和文件全都不显示名字了(如下图),是不是电脑中毒了呢 请教下笔者有没好的解决方法!下面是笔者给出的答案,希望能够帮助到大家! 首先打开你用来装图片的文件夹(缩略图下面的文字不显示的文件夹),然后但击工具栏上的“查看”选择“平铺”, 下面就是关键:要按住SHIFT键不...
解决方法: 其实处理这些使用流氓软件,需要将相关的.exe文件删除,使它不能再运行,或者直接清除这个服务本身,使计算机重启的时候,它不会再启动。比如Hijackthis扫描,在扫描日志中,一般会把非Windows系统的服务以023的方式列出来,如下面这段: O23 - ...
Windows 7系统可以对每个文件夹进行个性化视图设置,可以根据自己的个人喜好和实际需要更改文件或文件夹图标的大小,或者让文件或文件夹以列表、平铺等方式显示。但是,假如你对N个文件夹视图进行了风格各异的个性设置,现在又想让所有文件夹都使用同一种视图怎么办呢 手工一个一个修改,你OUT了,非累得手抽...
经过几天的测试后发现,Windows 7用户反映的情况确实存在,但并没有达到“频繁”的情况。同时,也并非是迅雷或快车抢了带宽。(即便是抢了带宽,表现的形式也是页面打开慢,而非是掉线),寻找问题的原因过程中,我们认为是Windows 7系统对于网卡的电源管理的默认设置造成的。 下面,就以Window...
公司用的是Windows 7,家里用的Mac OSX,又有iPad,iPhone。通过iClond可实现Safari的书签同步。这样在任何一个设备上添加了一个网址到书签里,其它设备都能保持更新。 首先需要做的是注册一个apple id。 Windows 7下需要安装一个iClond控制面板。虽然...
对于一台电脑来说,使用时间长久之后,感觉硬盘空间总是被填充的非常满,在寻找相隔时间较长的文件的时候比较费时,那么就要采用搜索的功能了。我们知道,Windows 7开始菜单下就有搜索导航,使得文件查找更加轻松便利。 首先按普通操作的方法在Windows 7开始菜单搜索条中输入要查找的文件关键...