什么?MySQL的等值查询竟然出错了?

1.问题背景

前段时间,一个业务线的小伙伴大G找过来,如下是我俩的对话。

大G:云杰,听说你MySQL挺厉害的,我最近遇到一个奇怪问题,不知道你遇到过没,请教你下。

我:请教不敢当,我也就是个MySQL入门级选手,说来看看。

大G:WHERE条件去等值查询字符串,结果却查出来几条尾部有空格的,明明不相等。

我:不会吧?这么神奇,这个真没遇到过!

大G:不信你试试!

我:试试就试试!

抱着求知的心态,开启了本篇的探索之旅。

2.验证

2.1 数据准备

首先在测试库里建表,并准备相关的原数据。创建个user_info表,分别插入’adu'(无空格)、’adu ‘(一个空格)、’adu    ‘(四个空格)三个用户。

CREATETABLE`user_info` (
`id`BIGINT(20) UNSIGNEDNOTNULLAUTO_INCREMENTCOMMENT'主键自增ID',
`user_name`VARCHAR(64) NOTNULLDEFAULT''COMMENT'名字',

PRIMARYKEY (`id`),
KEY`idx_user_name` (`user_name`)
) ENGINE=InnoDBDEFAULTCHARSET=utf8mb4COMMENT='用户表';

INSERTINTOuser_info(user_name) values('adu'); #无空格
INSERTINTOuser_info(user_name) values('adu '); #一个空格
INSERTINTOuser_info(user_name) values('adu '); #四个空格

2.2 问题验证

2.2.1 尾部空格验证

SELECT*FROMuser_infoWHEREuser_name='adu'; #无空格
SELECT*FROMuser_infoWHEREuser_name='adu '; #一个空格
SELECT*FROMuser_infoWHEREuser_name='adu '; #两个空格
SELECT*FROMuser_infoWHEREuser_name='adu '; #四个空格

我们使用如上条件去查,还真复现了!无论查询中尾部带有几个空格,结果是一样的,都会命中’adu’、’adu ‘、’adu    ‘三个用户,结果如下图所示(红框圈起来的表示我们认为不应该出现的异常结果):

太神奇了!

2.2.2 头部空格验证

那如果把空格放在前面呢?再来一把,结果如下:这下又匹配不上了。空格放在后边可以,放在前边不可以,这太神奇了!!

2.2.3 唯一索引验证

那如果在user_name字段上建唯一索引,还能插入这三条记录吗?再来一把,结果如下:

也不行,被唯一索引约束住了。

2.2.4 长度验证

那这三条记录的user_name长度又分别是多少呢?

确实长度也不一样。

2.3 验证小结

从结果上来看,明明是三个长度不同的字符串,空格放在前边被认为是不同,放在后边又被认为是相同,而且唯一索引也冲突。我们有充足的理由怀疑MySQL忽略字符串尾部的空格,把’adu’、’adu ‘、’adu    ‘都当成’adu’来处理。这确实超出了已有的认知,那背后的原因究竟又是什么呢?

3.分析原因

查询MySQL的官方文档[1],原来跟字符串的校对规则有关。

原来MySQL的校对规则基于PAD SPACE,这就意味着CHAR、VARCHAR、TEXT等字符串的等值比较(“=”)会忽略掉尾部的空格,而且官网也说了,适用于所有MySQL版本,并且不会改变。这。。。

既然MySQL官网说的这么肯定,那么自信来自哪里呢?我们继续追查SQL规范,原来SQL规范还真对这块做了特别说明[2],如下所示:

既然规范都这样要求了,等值查询“=”不能精确查询,那么到底该如何精确地进行等值查询呢?

4.精确查询的方法

通过调研,我们可以通过以下两种方式进行精确等值查询。

4.1 LIKE

LIKE是基于逐个字符进行比较的,这样就不会忽略尾部的空格,官网对这块也有特别的说明。

那么我们再使用LIKE进行等值查询,结果还真可以!

4.2 BINARY

BINARY不是函数,是类型转换运算符,它用来强制它后面的字符串转为二进制字节,再逐个字节比较,也可以理解成精确匹配,官网[4]对这块也有特别的说明。

那么我们再使用BINARY进行等值查询,结果也是可以的。

5.总结

  • MySQL的CHAR、VARCHAR、TEXT等字符串字段在等值比较(”=”)时,基于PAD SPACE校对规则,会忽略掉尾部的空格;
  • 在存储时,不会自动截断尾部的空格,会按原值存储;
  • 如果想要精确查询就不能用等值查询(”=”),而应改用LIKE或BINARY;
  • 认知有界,而求知无界。

关于作者

杜云杰,高级架构师,转转架构部负责人,转转技术委员会执行主席,腾讯云TVP。负责服务治理、MQ、云平台、APM、IM、分布式调用链路追踪、监控系统、配置中心、分布式任务调度平台、分布式ID生成器、分布式锁等基础组件。

道阻且长,拥抱变化;而困而知,且勉且行。

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/230844.html<

(0)
运维的头像运维
上一篇2025-04-19 10:25
下一篇 2025-04-19 10:26

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注