关于likeRight的用法 在使用Mybatis-plus的时候,使用like方法发现匹配的方法和自己想的相反,特此记录下: 使用场景: 我想要查询分类的某一层级下的订单,如下图,我想查询所有男装订
关于likeRight的用法在使用Mybatis-plus的时候,使用like方法发现匹配的方法和自己想的相反,特此记录下: 使用场景: 我想要查询分类的某一层级下的订单,如下图,我想查询所有“男装”订单 那么,如果是写SQL查询就是这样
可是,项目如果使用的是Mybatis-plus,那么我们该怎么写呢? 最开始我想的是,likeLeft就是左匹配嘛,就按照下面这么写:
哦豁,没查到数据。然后就换成likeRight之后,bingo 数据出来了: 然后,我就默默的去看了下源码(从上到下,层层递进,直到最后我们找到了转换SQL的地方,对!就是那个SqlUtils):
原来,它的likeLeft就是‘%’这个玩意儿加在左侧,likeRight就是加在右侧,默认就是两边都加,也就是like!!! 使用like与likeright方法查询信息的踩坑先说结论,like 和 likeRight的区别就是
所以使用的时候要搞清楚自己的需求,盲目使用like查询会造成隐患。 案例想要抽取 一串数字第7和8位组成是03的数据。 例子
结果应该是第3个和第6个。 然后我的like语句是 like("number", "______" + 03 + "%") //下划线_ 代表占位符,表示这个位置的数字随意,但是一个占位符表示只能有一个字符,意思表示为:前面6位数字随意。但第7,8位必须要03. 然而结果是第2,3,6个,这个结果导致我一系列操作直接全部迷惑操作,把数据全大变样。 最后知道原因,原来mybatisplus的like方法,会在执行sql的时候给参数前后都加上%,这就导致我的6个下划线失效, 所以数据混乱。 然后我换成likeRight就结果问题了,在找bug的时候,我从前端找到后端,从页面找到请求,再检查有没有写错,最后发现,数据库这里出错了,费了好大劲,太难了。 以后用like查询的时候可要用对了,还是没有系统的学习mybatisplus,基础不好所导致的问题 |
2021-06-05
2021-05-27
2021-05-26
2021-06-05
2021-05-16