欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 文旅 > 文化 > MyBatisPlus 中,模糊查询

MyBatisPlus 中,模糊查询

2025/4/1 3:48:58 来源:https://blog.csdn.net/weixin_45737215/article/details/146613154  浏览:    关键词:MyBatisPlus 中,模糊查询

在 MyBatisPlus 中,模糊查询主要通过 QueryWrapper 或 LambdaQueryWrapper 来实现,以下是一些常见的模糊查询方法及示例:
常见模糊查询方法
方法名    描述    示例 SQL
`like`    前后模糊匹配,即 `%值%`    `name LIKE '%J%'`
`notLike`    不模糊匹配,即 `NOT LIKE %值%`    `name NOT LIKE '%J%'`
`likeLeft`    左模糊匹配,即 `%值`    `name LIKE '%J'`
`likeRight`    右模糊匹配,即 `值%`    `name LIKE 'J%'`
`notLikeLeft`    不左模糊匹配,即 `NOT LIKE %值`    `name NOT LIKE '%J'`
`notLikeRight`    不右模糊匹配,即 `NOT LIKE 值%`    `name NOT LIKE 'J%'`
示例代码
使用 QueryWrapper
QueryWrapper<User> queryWrapper = new QueryWrapper<>();

// 查询姓名包含 "佳" 的用户
queryWrapper.like("name", "佳"); // SQL: name LIKE '%佳%'

// 查询姓名不包含 "佳" 的用户
queryWrapper.notLike("name", "佳"); // SQL: name NOT LIKE '%佳%'

// 查询姓名以 "黄" 开头的用户
queryWrapper.likeRight("name", "黄"); // SQL: name LIKE '黄%'

// 查询姓名以 "佳" 结尾的用户
queryWrapper.likeLeft("name", "佳"); // SQL: name LIKE '%佳'

使用 LambdaQueryWrapper
LambdaQueryWrapper<User> lambdaQueryWrapper = new LambdaQueryWrapper<>();

// 查询姓名包含 "J" 的用户
lambdaQueryWrapper.like(User::getName, "J"); // SQL: name LIKE '%J%'

// 查询姓名不包含 "J" 的用户
lambdaQueryWrapper.notLike(User::getName, "J"); // SQL: name NOT LIKE '%J%'

// 查询姓名以 "e" 结尾的用户
lambdaQueryWrapper.likeLeft(User::getName, "e"); // SQL: name LIKE '%e'

// 查询姓名以 "张" 开头的用户
lambdaQueryWrapper.likeRight(User::getName, "张"); // SQL: name LIKE '张%'

注意事项
•  在实际开发中,通常会结合条件判断来动态构建查询条件,例如使用 StringUtils.hasText() 来判断参数是否有效,避免空值导致的异常。
•  QueryWrapper 和 LambdaQueryWrapper 的使用方式类似,但 LambdaQueryWrapper 提供了更安全的字段引用方式,推荐使用。
•  模糊查询时,% 是 SQL 中的通配符,表示匹配任意长度的字符,而 _ 表示匹配单个字符。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词