MySQL校对规则(COLLATION)的具体使用

 更新时间:2022年08月09日 15:18:30   作者:IT利刃出鞘  
本文主要介绍了MySQL校对规则(COLLATION)的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

简介

本文介绍MySQL的校对规则。

MySQL的校对规则

  • 两个不同的字符集不能有相同的校对规则。
  • 每个字符集有一个默认校对规则。例如:
    • utf8mb4默认校对规则:utf8mb4_general_ci。
    • utf8默认校对规则:utf8_general_ci。
  • 存在校对规则命名约定:它们以其相关的字符集名开始,通常包括一个语言名,并且以_ci(大小写不敏感)、_cs(大小写敏感)或_bin(二进制,大小写敏感)结束。

校对规则列举 

  • utf8mb4_general_ci
  • utf8mb4_unicode_ci
  • utf8mb4_general_cs
  • utf8mb4_bin

//不存在utf8_unicode_cs

查看校对规则

查看支持的校验规则

mysql> SHOW COLLATION like 'utf8%';
+--------------------------+---------+-----+---------+----------+---------+
| Collation                | Charset | Id  | Default | Compiled | Sortlen |
+--------------------------+---------+-----+---------+----------+---------+
| utf8_general_ci          | utf8    |  33 | Yes     | Yes      |       1 |
| utf8_bin                 | utf8    |  83 |         | Yes      |       1 |
| utf8_unicode_ci          | utf8    | 192 |         | Yes      |       8 |
...
| utf8mb4_general_ci       | utf8mb4 |  45 | Yes     | Yes      |       1 |
| utf8mb4_bin              | utf8mb4 |  46 |         | Yes      |       1 |
| utf8mb4_unicode_ci       | utf8mb4 | 224 |         | Yes      |       8 |
| utf8mb4_icelandic_ci     | utf8mb4 | 225 |         | Yes      |       8 |

查看本地的校验规则

mysql> show global variables like '%coll%';
+----------------------+--------------------+
| Variable_name        | Value              |
+----------------------+--------------------+
| collation_connection | utf8mb4_unicode_ci |
| collation_database   | utf8mb4_unicode_ci |
| collation_server     | utf8mb4_unicode_ci |
+----------------------+--------------------+

修改校对规则

修改数据库配置后,不会对已经存在的表造成影响,如要生效需要修改特定列的排序规则。优先级:列>表>数据库>服务器。

对已存在的表修改

# 修改数据库:  
ALTER DATABASE database_name CHARACTER SET = utf8mb4 COLLATE = utf8mb4_bin;  
# 修改表:  
ALTER TABLE table_name CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_bin;  
# 修改表字段:  
ALTER TABLE table_name CHANGE column_name column_name VARCHAR(191) CHARACTER SET utf8mb4 COLLATE utf8mb4_bin NOT NULL ; 

创建表时指定

CREATE TABLE `T` (
  `name` varchar(20) COLLATE utf8mb4_unicode_ci DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci

utf8_general_ci 与 utf8_unicode_ci区别

utf8mb4_unicode_ciutf8mb4_general_ci总结
准确性基于标准的Unicode来排序和比较,能够在各种语言之间精确排序没有实现Unicode排序规则,在遇到某些特殊语言或字符时,排序结果可能不是所期望的。绝大多数情况下,特殊字符的顺序不需要那么精确。
性能在特殊情况下,Unicode排序规则为了能够处理特殊字符的情况,实现了略微复杂的排序算法。在比较和排序的时候更快

绝大多数情况下,不会发生此类复杂比较。

总结:

utf8_unicode_ci比较准确,utf8_general_ci速度比较快。

通常情况下 utf8_general_ci 的准确性就够我们用的了,在我看过很多程序源码后,发现它们大多数也用的是utf8_general_ci,所以新建数据 库时一般选用utf8_general_ci就可以了。

如果是utf8mb4那么对应的就是 utf8mb4_general_ci utf8mb4_unicode_ci

到此这篇关于MySQL校对规则(COLLATION)的具体使用的文章就介绍到这了,更多相关MySQL 校对规则内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 最新MySQL数据库漏洞情况通报

    最新MySQL数据库漏洞情况通报

    本文是对近期mysql报出的漏洞情况进行了简单的说明以及漏洞的修复措施分享,有需要的小伙伴一定要关注下
    2016-09-09
  • MYSQL插入数据时检查字段值是否重复的方法详解

    MYSQL插入数据时检查字段值是否重复的方法详解

    这篇文章主要给大家介绍了关于MYSQL插入数据时检查字段值是否重复的相关资料,文中通过实例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2022-01-01
  • mysql存储过程实例

    mysql存储过程实例

    这篇文章主要介绍了mysql存储过程实例,需要的朋友可以参考下
    2014-04-04
  • 一文弄懂MySQL索引创建原则

    一文弄懂MySQL索引创建原则

    在关键字段的索引上建与不建索引,查询速度相差近100倍,但差的索引和没有索引效果一样,索引并非越多越好,因为维护索引需要成本,下面这篇文章主要给大家介绍了关于MySQL索引创建原则的相关资料,需要的朋友可以参考下
    2022-02-02
  • MySQL自定义函数和存储过程示例详解

    MySQL自定义函数和存储过程示例详解

    这篇文章主要给大家介绍了关于MySQL自定义函数和存储过程的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用MySQL具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-04-04
  • CentOs7 64位 mysql 5.6.40源码安装过程

    CentOs7 64位 mysql 5.6.40源码安装过程

    这篇文章主要介绍了CentOs7 64位 mysql-5.6.40源码安装过程,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-01-01
  • mysql使用Haversine 公式和ST_Distance_Sphere 函数实现附近的人功能

    mysql使用Haversine 公式和ST_Distance_Sphere 函数实现附近的人功能

    使用 MySQL 来实现“附近的人”功能,可以通过Haversine 公式和ST_Distance_Sphere 函数两种方式来实现,这篇文章主要介绍了mysql实现附近的人功能,需要的朋友可以参考下
    2023-08-08
  • Mysql:The user specified as a definer (''xxx@''%'') does not exist的解决方案

    Mysql:The user specified as a definer (''xxx@''%'') does not

    今天小编就为大家分享一篇关于Mysql:The user specified as a definer ('xxx@'%') does not exist的解决方案,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2018-12-12
  • MySql在Mac上的安装与配置详解

    MySql在Mac上的安装与配置详解

    这篇文章主要介绍了MySql在Mac上的安装配置,需要的朋友可以参考下
    2017-05-05
  • 理解MySQL存储过程和函数

    理解MySQL存储过程和函数

    这篇文章主要帮助大家学习理解MySQL存储过程和函数,感兴趣的小伙伴们可以参考一下
    2016-03-03

最新评论