sql 查询某字段带空格_一个空格引发的“惨案“

本文讲述了在SQL查询中遇到的空格匹配问题,MySQL默认忽略后置空格导致查询错误。通过使用BINARY关键字可以解决此问题,但在Oracle中不适用。文章探讨了在多数据库环境中如何处理这个问题,提出了面临的挑战并邀请读者分享解决方案。
摘要由CSDN通过智能技术生成
0d4fab4f0ae22b55fc6245907981b5c4.png

作者 | 践行精神自由

来源 | 互联网全栈架构

责编 | 屠敏

“案情”回顾(情景模拟):小张是一名软件工程师,工作兢兢业业、一丝不苟且精益求精,天性乐观的他每天愉快地做着增删改查的工作,对于这些看似简单的CRUD,小张从来不会掉以轻心,他也笃定地坚信,自己向数据库里插入了什么数据,就能按条件把这些数据查询出来,毕竟,像MySQL这样的数据库,在全世界广为流行,大行其道,不可能不严谨。

然而,意想不到的悲剧还是发生了。。。

小张做的项目与语言处理有点关系,他们把处理的结果也就是字符串保存到在数据库里面,后续需要按照条件把这些数据查询出来,但需要对这些字符串做严格的区分,也就是说,如果查询A字符串,不能把B字符串查询出来,哪怕这两个字符串只有一个空格的差异。对于这样的需求,小张觉得太天经地义了,根本无需多言,像MySQL这样的数据库天生就是干这样的事,所以当时就自信满满地拍着胸脯保证一定如期开发完成。

随着工作的推进,小张猛然发现MySQL对于字符串的处理貌似不那么严谨,特别是对于空格字符,比如这两个字符串:"Tom"和"Tom ",后面的字符串多了一个空格,然而&#

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值