栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

存储数据的奇怪字符编码,旧脚本正在向他们展示好的新脚本没有

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

存储数据的奇怪字符编码,旧脚本正在向他们展示好的新脚本没有

简而言之,因为这已经被讨论了上千次了:

  1. PHP拥有一个
    "漢字"
    以UTF-8编码的字符串,例如。的字节为
    E6 BC A2 E5 AD 97
  2. 它通过 设置为
    latin1
    数据库连接 发送此字符串。
  3. 数据库接收字节
    E6 BC A2 E5 AD 97
    ,认为这些字节代表
    latin1
    字符。
  4. 数据库存储字符
    æ¼¢å­
    E6 BC A2 E5 AD 97
    映射到中的字符
    latin1
    )。
  5. 反向执行相同的过程会使PHP接收相同的字节,然后将其视为UTF-8。即使数据库未按应有的方式对待字符,往返也适用于PHP。

因此,这里的问题是,当将数据输入数据库时​​,数据库连接设置不正确。您必须将数据库中的数据转换为正确的字符。尝试这个:

SELECt ConVERT(BINARY ConVERT(field_name USING latin1) USING utf8) FROM table_name

utf8
尝试一下,也许这不是您所需要的。如果可行,
UPDATE
请将其更改为语句以永久更新数据。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/416243.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号