博客
关于我
mysql支持表情
阅读量:798 次
发布时间:2023-02-12

本文共 628 字,大约阅读时间需要 2 分钟。

在实际开发中,可能会遇到需要存储表情符号的情况,尤其是在使用MySQL作为RDS时。如果不做任何处理,直接插入包含表情符号的文本,可能会导致“Incorrect String '\F0\F8'”等错误。这是因为MySQL数据库通常使用utf8编码,支持3字节的字符编码,而表情符号本身是4字节的UTF-16编码。为了解决这个问题,可以使用utf8mb4编码来实现兼容。

解决方法

  • 数据库字符集设置

    将数据库表的字符集设置为utf8mb4。

    alter table test1 convert to character set utf8mb4;
  • 客户端连接设置

    在程序中设置连接池的初始化SQL,使客户端编码集为utf8mb4。

    dataSource.setInitSql("set names utf8mb4");

  • 扩展:MySQL与Redis的区别

    为什么MySQL需要专门处理表情符号,而Redis不需要?

    这是因为MySQL是按字符进行编码的,而一个字符可能包含1-4个字节,这取决于所选的字符编码集。

    而Redis是按字节进行编码的,因此不会出现类似MySQL遇到的问题。


    注意事项

    • utf8mb4是MySQL的一个扩展字符集,能够完整支持所有UTF-16字符,包括emoji和复杂语言字符。
    • 如果仅存储ASCII字符,不需要启用utf8mb4,可以直接使用utf8编码。
    • emoji字符的支持取决于数据库的编码设置,正确配置后才能正常存储和检索。

    转载地址:http://cddfk.baihongyu.com/

    你可能感兴趣的文章
    Netty工作笔记0034---Netty架构设计--线程模型
    查看>>
    Netty工作笔记0035---Reactor模式图剖析
    查看>>
    Netty工作笔记0036---单Reactor单线程模式
    查看>>
    Netty工作笔记0037---主从Reactor多线程
    查看>>
    Netty工作笔记0038---Netty模型--通俗版
    查看>>
    Netty工作笔记0040---Netty入门--服务端1
    查看>>
    Netty工作笔记0041---Netty入门--服务端2
    查看>>
    Netty工作笔记0042---Netty入门--编写客户端
    查看>>
    Netty工作笔记0043---单Reactor多线程模式
    查看>>
    Netty工作笔记0044---Netty案例源码分析
    查看>>
    Netty工作笔记0044---scheduledTaskQueue
    查看>>
    Netty工作笔记0045---Netty模型梳理
    查看>>
    Netty工作笔记0045---异步模型原理剖析
    查看>>
    Netty工作笔记0046---TaskQueue自定义任务
    查看>>
    Netty工作笔记0046---异步模型原理剖析
    查看>>
    Netty工作笔记0047---Http服务程序实例
    查看>>
    Netty工作笔记0048---Http服务过滤资源
    查看>>
    Netty工作笔记0050---Netty核心模块1
    查看>>
    Netty工作笔记0051---Netty核心模块2
    查看>>
    Netty工作笔记0052---Pipeline组件剖析
    查看>>