mysql如何强制区分大小写

SELECT distinct name FROM users 这样SELECT distinct name 如何强制区分大小写呢?

bash 复制代码
SELECT DISTINCT BINARY name FROM users;

mysql的where条件的=号是不区分大小写的吗

-- 强制区分大小写,无论字段默认校对规则如何

bash 复制代码
SELECT * FROM users WHERE BINARY name = 'Alice'; -- 只匹配 'Alice'

默认情况下(大多数场景),不区分大小写常见的字符集(如 utf8、utf8mb4)默认使用的校对规则是 ci 结尾的(ci = Case Insensitive,不区分大小写),例如 utf8_general_ci、utf8mb4_general_ci。此时,= 比较会忽略大小写,例如:

bash 复制代码
-- 假设 name 字段的校对规则是 utf8_general_ci
SELECT * FROM users WHERE name = 'Alice';
SELECT * FROM users WHERE name = 'alice'; -- 与上面查询结果相同

如果使用 bin 结尾的校对规则,则区分大小写若字段的校对规则是 bin 结尾的(bin = Binary,二进制比较),例如 utf8_bin、utf8mb4_bin,则 = 会严格区分大小写,因为它比较的是字符的二进制编码(不同大小写的字符二进制值不同)。例如:

bash 复制代码
-- 假设 name 字段的校对规则是 utf8_bin
SELECT * FROM users WHERE name = 'Alice'; -- 只匹配 'Alice'
SELECT * FROM users WHERE name = 'alice'; -- 只匹配 'alice'(与上面结果不同)
相关推荐
rgeshfgreh2 分钟前
Spring事务传播机制深度解析
java·前端·数据库
无名-CODING3 分钟前
Java Spring 事务管理深度指南
java·数据库·spring
想唱rap9 分钟前
MYSQL在ubuntu下的安装
linux·数据库·mysql·ubuntu
蕨蕨学AI10 分钟前
【Wolfram语言】45.2 真实数据集
java·数据库
The Sheep 202318 分钟前
MongoDB与.Net6
数据库·mongodb
BryceBorder27 分钟前
SCAU--数据库
数据库·oracle·dba
java1234_小锋29 分钟前
MySQL中的乐观锁和悲观锁是什么?
mysql
有味道的男人32 分钟前
京东关键词API接口获取
数据库
罗光记1 小时前
《人工智能安全治理研究报告(2025年)发布
数据库·其他·百度·新浪微博
202321336054 刘1 小时前
Linux常用命令分类整理
linux·运维·数据库