tk mybatis通用mapper,复杂and or条件查询
需求:where查询,需要支持(a or b or c) and d
也就是a、b、c三个条件是或的关系,然后再与d相与。
尝试后,可以通过以下方式处理:
方式1:Weekend语法
Weekend<User> weekend = new Weekend<>(User.class); //关键字查询部分 String keyword = pageReq.getKeyword(); WeekendCriteria<User, Object> keywordCriteria = weekend.weekendCriteria(); if (StringUtils.isNotEmpty(keyword)) { keywordCriteria.orLike(User::getUserName, keyword).orLike(User::getPoliceNo, keyword).orLike(User::getRealName, keyword);
//此处不需要再用下面这一句了,不然上面这个条件组合会重复一次
//weekend.and(keywordCriteria)
}
//部门查询部分 Example example = new Example(User.class); Example.Criteria criteria = example.createCriteria(); criteria.andEqualTo("departmentId", departmentId); weekend.and(criteria); PageHelper.startPage(pageReq.getPageIndex(), pageReq.getPageSize()); List<User> users = userMapper.selectByExample(weekend);
ps:上面,其中Weekend是高版本的通用mapper版本才有,而且需要java8语法支持。
方式2:通用example语法:
Example e = new Example(User.class); Example.Criteria c = e.createCriteria(); //关键字查询部分 String keyword = pageReq.getKeyword(); if (StringUtils.isNotEmpty(keyword)) { c.orEqualTo("userName", keyword).orEqualTo("policeNo",keyword).orEqualTo("realName",keyword); } //部门查询部门 Example.Criteria criteria = e.createCriteria(); criteria.andEqualTo("departmentId", departmentId); e.and(criteria); PageHelper.startPage(pageReq.getPageIndex(), pageReq.getPageSize()); List<User> users = userMapper.selectByExample(e);
执行的sql为:
WHERE ( user_name = ? OR police_no = ? OR real_name = ? ) AND (department_id = ?)
总结下来,就是,
每个条件组合(a/b/c) (d)各自创建自己的cirteria,再用and或者or方法去连接
分类:
DAO层框架
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 周边上新:园子的第一款马克杯温暖上架
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?
· 使用C#创建一个MCP客户端