mybatis-plus使用like与likeright方法查询信息,踩坑

4 篇文章 0 订阅
4 篇文章 0 订阅
本文通过一个具体的案例分析了在SQL查询中like和likeRight方法的区别。like方法在执行时会在查询参数前后自动添加通配符%,可能导致预期外的结果。而likeRight仅在参数右侧添加通配符,更适用于特定场景。作者在查找数据错误时,耗费大量精力才发现问题根源在于对mybatisplus的like方法理解不准确。因此,强调在使用SQL查询时要明确需求,避免类似陷阱。
摘要由CSDN通过智能技术生成

先说结论,like 和 likeRight的区别就是
like: 填入query的参数两端加上通配符,会进行左右两端进行like匹配
likeRight:只给填入参数的右端加入通配符进行匹配。
所以使用的时候要搞清楚自己的需求,盲目使用like查询会造成隐患。

案例:
想要抽取 一串数字第7和8位组成是03的数据。
例子

  1. 2022010101
  2. 2022010203
  3. 2022010302
  4. 2022020102
  5. 2022020204
  6. 2022020301
    结果应该是第3个和第6个。
    然后我的like语句是
like("number", "______" + 03 + "%") //下划线_ 代表占位符,表示这个位置的数字随意,但是一个占位符表示只能有一个字符,意思表示为:前面6位数字随意。但第7,8位必须要03.

然而结果是第2,3,6个,这个结果导致我一系列操作直接全部迷惑操作,把数据全大变样。
最后知道原因,原来mybatisplus的like方法,会在执行sql的时候给参数前后都加上%,这就导致我的6个下划线失效, 所以数据混乱。
然后我换成likeRight就结果问题了,在找bug的时候,我从前端找到后端,从页面找到请求,再检查有没有写错,最后发现,数据库这里出错了,费了好大劲,太难了。
以后用like查询的时候可要用对了,还是没有系统的学习mybatisplus,基础不好所导致的问题。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: 在 MyBatis-Plus 中,你可以使用 Lambda 表达式来构建复杂的 SQL 查询条件。如果你想在 SQL 查询条件中加括号,可以使用 Lambda 表达式中的 `and` 和 `or` 方法来实现。 例如,假设你有一个用户表,希望查询年龄大于 18 岁或者名字以 "J" 开头的用户。你可以这样写: ``` List<User> users = userMapper.selectList(new QueryWrapper<User>() .lambda() .and(age -> age.ge(18)) .or(name -> name.likeRight("J%")) ); ``` 这样生成的 SQL 语句就会带上括号,类似这样: ``` SELECT * FROM user WHERE (age >= 18) OR (name LIKE 'J%') ``` 如果你想在条件中嵌套更多的括号,可以使用 Lambda 表达式的 `and` 和 `or` 方法的重载版本,接受一个 `Function<QueryWrapper<T>, QueryWrapper<T>>` 类型的参数,这样就可以在括号内再嵌套一个 Lambda 表达式了。 例如,假设你想查询年龄大于 18 岁并且名字以 "J" 开头或者邮箱以 "example.com" 结尾的用户,你可以这样写: ``` List<User> users = userMapper.selectList(new QueryWrapper<User>() .lambda() .and(age -> age.ge(18)) .and(name -> name.likeRight("J%")) .or(query -> query.lambda() .and(email -> email.like("%example.com")) ) ); ``` 这样生成的 SQL 语句就会带上括号,类似这样: ``` SELECT * FROM user WHERE (age >= 18) AND (name LIKE ' ### 回答2: 使用Mybatis-PlusSQL查询条件中加括号的方法使用Wrapper构建查询条件,并使用lambda表达式和括号来组合条件。 首先,创建一个Wrapper对象,可以使用`QueryWrapper`或`LambdaQueryWrapper`来构建。以`LambdaQueryWrapper`为例: ```java LambdaQueryWrapper<User> wrapper = new LambdaQueryWrapper<>(); ``` 然后,在Wrapper对象中使用lambda表达式来定义查询条件,并使用括号来分组条件。例如,查询年龄小于30或者姓名为"张三"的用户: ```java wrapper.and(w -> w.lt(User::getAge, 30).or().eq(User::getName, "张三")); ``` 在这个例子中,括号内的条件`.lt(User::getAge, 30)`表示查询年龄小于30,`.or()`表示或运算,`.eq(User::getName, "张三")`表示查询姓名为"张三"。整个表达式的意思是查询满足括号内条件的用户。 最后,将Wrapper对象作为参数传递给Mybatis-Plus查询方法,如`selectList()`、`selectOne()`等。 这样就可以在Mybatis-Plus使用括号来组合查询条件了。 ### 回答3: 在MyBatis-Plus中,在SQL查询条件中加括号可以通过使用实体类的QueryWrapper对象来实现。QueryWrapper是MyBatis-Plus提供的一个查询封装类,可以方便地构建查询条件。 首先,需要创建一个QueryWrapper对象。可以使用QueryWrapper的构造函数创建一个空的QueryWrapper对象,然后使用它的方法来添加查询条件。 然后,可以使用QueryWrapper对象提供的方法来添加查询条件。例如,可以使用eq方法添加等于条件,使用like方法添加模糊查询条件。 如果需要在SQL查询条件中加括号,可以使用and方法或者or方法来将多个条件加括号。例如,可以使用and方法将多个相等条件加括号。 最后,调用MyBatis-Plus提供的mapper的select方法,将QueryWrapper对象作为参数传入,就可以执行查询操作。查询结果将会被封装成一个List集合返回。 综上所述,MyBatis-Plus中在SQL查询条件中加括号可以通过使用QueryWrapper对象来实现。通过构建QueryWrapper对象并使用它的方法来添加查询条件,然后将QueryWrapper对象作为参数传入select方法进行查询操作。这样就可以在SQL查询条件中加括号实现更复杂的查询条件组合。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

酷奥空间

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值