mysql数据库中utf8mb4 unicode ci和utf8 general ci什么区别?

utf8mb4是4个字节。utf8是3个字节。utf8mb4兼容性更好,占用空间更大。算法

主要从排序准确性和性能两方面看:性能

    • 准确性
      utf8mb4_unicode_ci 是基于标准的Unicode来排序和比较,可以在各类语言之间精确排序
      utf8mb4_general_ci 没有实现Unicode排序规则,在遇到某些特殊语言或字符是,排序结果可能不是所指望的。
    • 性能
      utf8mb4_general_ci 在比较和排序的时候更快
      utf8mb4_unicode_ci 在特殊状况下,Unicode排序规则为了可以处理特殊字符的状况,实现了略微复杂的排序算法。
      可是在绝大多数状况下,不会发生此类复杂比较。general理论上比Unicode可能快些,但相比如今的CPU来讲,它远远不足以成为考虑性能的因素,索引涉及、SQL设计才是。 我我的推荐是 utf8mb4_unicode_ci,未来 8.0 里也极有可能使用变为默认的规则。相比选择哪种collation,使用者应该更关心字符集与排序规则在db里要统一就好。
相关文章
相关标签/搜索