Mysql的utf8mb4_general_ci 与 utf8mb4_bin 的具体区别是什么?中文适合哪个?

MySQL排序规则区别及中文适用选择

1. utf8mb4_general_ci vs utf8mb4_bin 的具体区别

utf8mb4_general_ciutf8mb4_bin 都是 utf8mb4 编码的排序规则(collation),它们主要在 排序(ORDER BY)比较(WHERE) 时的行为不同:

排序规则 是否区分大小写 是否区分重音 速度 适用场景
utf8mb4_general_ci ❌ 不区分 ❌ 不区分 ✅ 更快 适用于一般文本,如用户名、标题
utf8mb4_bin ✅ 区分 ✅ 区分 ⛔ 更慢 适用于密码、唯一标识符
(1) utf8mb4_general_ci(Case-Insensitive,不区分大小写)
  • CI 代表 “Case Insensitive”,表示比较时 不区分大小写,也 不区分重音符号
  • 例如:
    SELECT 'a' = 'A';  -- 结果是 TRUE
    SELECT 'résumé' = 'resume'; -- 结果是 TRUE
    
    utf8mb4_general_ci 主要适用于 对大小写或重音符号不敏感的文本(如用户名、标签等)。
(2) utf8mb4_bin(Binary,区分大小写)
  • utf8mb4_bin 按照 二进制编码 逐字节进行比较,因此大小写、重音符号完全不同。
  • 例如:
    SELECT 'a' = 'A' COLLATE utf8mb4_bin; -- 结果是 FALSE
    SELECT 'résumé' = 'resume' COLLATE utf8mb4_bin; -- 结果是 FALSE
    
    utf8mb4_bin 适用于 严格区分大小写的场景(如密码、文件名、唯一标识符)。

2. 除了 utf8mb4_general_ciutf8mb4_bin,还有哪些?

utf8mb4 编码有多种排序规则,主要区别在于:

  • 是否区分大小写
  • 是否区分重音
  • 排序算法
(1) 常见的 utf8mb4 排序规则
MySQL中的`utf8mb4`字符集支持多种排序规则(collation),其中`utf8mb4_bin`和`utf8mb4_general_ci`是两种常见的排序规则,它们在排序和比较行为上有显著的区别。 ### 排序规则概述 - `utf8mb4_bin`:按照二进制编码逐字节进行比较,区分大小写和重音符号。这意味着在比较字符串时,每个字符的字节值都会被精确地比较。例如,`'a'`和`'A'`会被视为不同的字符串,`'résumé'`和`'resume'`也会被视为不同的字符串。 - `utf8mb4_general_ci`:不区分大小写和重音符号,CI代表“Case Insensitive”。这意味着在比较字符串时,大小写和重音符号会被忽略。例如,`'a'`和`'A'`会被视为相同的字符串,`'résumé'`和`'resume'`也会被视为相同的字符串。 ### 区别 1. **大小写敏感性**: - `utf8mb4_bin`区分大小写,因此`'a'`和`'A'`被视为不同的字符。 - `utf8mb4_general_ci`不区分大小写,因此`'a'`和`'A'`被视为相同的字符。 2. **重音符号敏感性**: - `utf8mb4_bin`区分重音符号,因此`'é'`和`'e'`被视为不同的字符。 - `utf8mb4_general_ci`不区分重音符号,因此`'é'`和`'e'`被视为相同的字符。 3. **性能**: - `utf8mb4_general_ci`在比较时速度更快,因为它不需要进行逐字节的比较。 - `utf8mb4_bin`在比较时速度较慢,因为它需要进行逐字节的比较。 4. **适用场景**: - `utf8mb4_general_ci`适用于对大小写或重音符号不敏感的文本,如用户名、标题等。 - `utf8mb4_bin`适用于严格区分大小写的场景,如密码、文件名、唯一标识符等。 ### 示例代码 以下是一个简单的SQL示例,展示了不同排序规则下的比较行为: ```sql -- 使用 utf8mb4_general_ci 进行比较 SELECT 'a' = 'A' COLLATE utf8mb4_general_ci AS result; -- 结果是 TRUE -- 使用 utf8mb4_bin 进行比较 SELECT 'a' = 'A' COLLATE utf8mb4_bin AS result; -- 结果是 FALSE ``` ###
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值