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'(与上面结果不同)
相关推荐
weixin19970108016几秒前
锦程物流item_get - 获取详情接口对接全攻略:从入门到精通
数据库·python
AC赳赳老秦3 分钟前
DeepSeek 辅助科研项目申报:可行性报告与经费预算框架的智能化撰写指南
数据库·人工智能·科技·mongodb·ui·rabbitmq·deepseek
2501_927773073 分钟前
Linux系统编程——sqlite数据库
数据库
mahailiang7 分钟前
codeblocks+wxWidgets Projects中引用第三方库(sqlite3)
数据库·sqlite·wxwidgets·codeblocks
凉年技术14 分钟前
MySQL 5.6 2000 万行高频读写表新增字段实战:从慢执行到无锁落地全解析
mysql
cyforkk28 分钟前
09、Java 基础硬核复习:异常处理(容错机制)的核心逻辑与面试考点
java·数据库·面试
CC.GG43 分钟前
【Linux】进程控制(二)----进程程序替换、编写自主Shell命令行解释器(简易版)
linux·服务器·数据库
2301_765703141 小时前
开发一个简单的Python计算器
jvm·数据库·python
QCzblack1 小时前
第三周作业
数据库