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

作者:深空 来源:蓝色理想 时间:2007-08-23 16:10:00 

以下所描述无理论依据,纯属经验谈

MySQL使用4.1以上版本,管他是什么字符集,一律使用默认。不用去设置MySQL。

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

好,你只要保证你的写着Insert SQL语句的PHP文件编码为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指定为何种编码,他在录入数据的时候,并不会对你的数据进行转换。只要保证你的前端录入使用UTF-8,那么你读取的也是UTF-8。

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

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

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

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

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

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

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

标签:mysql,编码
0
投稿

猜你喜欢

  • vue parseHTML函数解析器遇到结束标签

    2023-07-02 16:56:09
  • python3.6根据m3u8下载mp4视频

    2021-05-22 00:20:03
  • vuex页面刷新后数据丢失的方法

    2024-05-09 15:19:29
  • 精简版的MySQL制作步骤

    2011-03-08 09:52:00
  • SqlServer 索引自动优化工具

    2012-10-07 10:41:09
  • SQL Server中将数据导出为XML和Json方法分享

    2024-01-22 19:04:22
  • pytorch-gpu安装的经验与教训

    2022-01-11 20:23:36
  • 理解Python中的With语句

    2023-02-09 17:22:33
  • 图文详解mysql中with...as用法

    2024-01-27 20:52:43
  • python爬虫使用cookie登录详解

    2023-10-13 06:36:39
  • django 自定义filter 判断if var in list的例子

    2022-09-25 16:11:37
  • ASP获取ACCESS数据库的表名以及表名对应的字段名和字段类型

    2009-12-25 18:57:00
  • python利用urllib实现爬取京东网站商品图片的爬虫实例

    2022-05-01 12:32:56
  • Django中和时区相关的安全问题详解

    2021-02-24 11:40:44
  • 代码详解Python的函数基础(1)

    2023-08-16 17:47:22
  • Mysql 执行一条语句的整个过程详细

    2024-01-19 08:53:08
  • python爬取淘宝商品销量信息

    2023-06-01 14:59:03
  • 详解微信小程序网络请求接口封装实例

    2024-06-12 04:08:54
  • WEB2.0网页制作标准教程(8)CSS布局入门

    2007-09-11 13:21:00
  • Pytorch转keras的有效方法,以FlowNet为例讲解

    2023-07-27 02:04:54
  • asp之家 网络编程 m.aspxhome.com