作者 | 践行精神自由
来源 | 互联网全栈架构
责编 | 屠敏
“案情”回顾(情景模拟):小张是一名软件工程师,工作兢兢业业、一丝不苟且精益求精,天性乐观的他每天愉快地做着增删改查的工作,对于这些看似简单的CRUD,小张从来不会掉以轻心,他也笃定地坚信,自己向数据库里插入了什么数据,就能按条件把这些数据查询出来,毕竟,像MySQL这样的数据库,在全世界广为流行,大行其道,不可能不严谨。
然而,意想不到的悲剧还是发生了。。。
小张做的项目与语言处理有点关系,他们把处理的结果也就是字符串保存到在数据库里面,后续需要按照条件把这些数据查询出来,但需要对这些字符串做严格的区分,也就是说,如果查询A字符串,不能把B字符串查询出来,哪怕这两个字符串只有一个空格的差异。对于这样的需求,小张觉得太天经地义了,根本无需多言,像MySQL这样的数据库天生就是干这样的事,所以当时就自信满满地拍着胸脯保证一定如期开发完成。
随着工作的推进,小张猛然发现MySQL对于字符串的处理貌似不那么严谨,特别是对于空格字符,比如这两个字符串:"Tom"和"Tom ",后面的字符串多了一个空格,然而&#