• php中 mysql 插入特殊字符(手机端的emoji表情)出现异常


    今天在用mysql存储从微信服务器拉来的数据,出现插入数据异常,报 Incorrect string value: 'xF0x9Fx98x97xF0x9F 的错误。
    最终在网上查了一下,有几个解决方案:
     
    方案一:
    如果是用thinkphp开发的话,在tinhkphp  config.php中连接数据库配置文件中 设置
    'DB_CHARSET'=> 'utf8mb4', // 字符集
    这样就可以解决问题。
    如果没用thinkphp开发,直接使用php开发的话,在执行sql语句的时候,要添加
    mysql_query("set names utf8");或者 mysql_query("set character_set_client utf8mb4");
    方案二:
     把mysql数据库升级到5.5以上,然后数据库编码设置为utf8mb4,字段的编码最好也为utf8mb4。
     
     
    问题:用户个人信息设置时使用emoji表情,MySQL如果不是utf8mb4会导致异常。
    SHOW VARIABLES LIKE 'collation_%';     -----查看mysql 系统编码
    SHOW VARIABLES LIKE 'char%'; 

    SET    NAMES utf8;  ----相当于设置了 character_set_client、character_set_connection、character_set_results
    SET   NAMES utf8mb4;
    SET   character_set_client=utf8mb4;    ----针对特殊字符
    SET   character_set_connection=utf8mb4;--针对特殊字符
    SET   character_set_results=utf8mb4;

    总之,就是在character_set_client或者character_set_connection中,至少一个的编码为utf8mb4。
    utf8mb4这种格式,就是为了兼容手机端的,比UTF-8多了好多格式,包括了UTF-8的格式。
     
     
  • 相关阅读:
    第一阶段-坑爹猴
    终于做出来了
    一天就制作成了这些
    累成狗做出来的
    一周的学习,组合起来的成就
    刚刚出炉的搜狗浏览器最新版本
    自己动手设计了一下下百度首页
    数论:卢卡斯定理(求组合数)
    数据结构:ST表模板(可维护区间RMQ)
    快读和快写(可以使用__int128)
  • 原文地址:https://www.cnblogs.com/luoyangcn/p/4363924.html
Copyright © 2020-2023  润新知