循环添加条件、联表查询

QueryWrapper是MyBatis-Plus提供的一个查询构建器,用于构建复杂的SQL查询语句。QueryWrapper可以用于添加条件、排序、分页等操作。

循环添加条件

在QueryWrapper中,可以使用andWhere和orWhere方法来添加多个条件,从而实现循环添加条件。

下面是一个示例代码,演示如何使用QueryWrapper循环添加条件:

swift 复制代码
QueryWrapper<User> wrapper = new QueryWrapper<>();List<String> keywords = Arrays.asList("张三", "李四", "王五");for (String keyword : keywords) {wrapper.or(wp->wp.eq("name", ConditionOperator.LIKE, "%" + keyword + "%"));}List<User> userList = userMapper.selectList(wrapper);

在上面的代码中,我们首先创建了一个QueryWrapper对象,然后定义了一个包含多个关键字的列表。接着,我们使用for循环遍历这个列表,为QueryWrapper对象添加多个条件。在每次循环中,我们使用andWhere方法添加一个新的条件,这个条件是查询用户名包含当前关键字。最后,我们调用UserMapper的selectList方法执行查询操作,并将查询结果保存在userList中。

联表查询

下面是一个示例代码,演示如何使用QueryWrapper实现联表查询:

sql 复制代码
QueryWrapper<User> wrapper = new QueryWrapper<>();wrapper.leftJoin(new Join("user_role", "user.id = user_role.user_id"), true);List<User> userList = userMapper.selectList(wrapper);

在上面的代码中,我们首先创建了一个QueryWrapper对象,然后使用leftJoin方法进行联表查询。这个方法接受两个参数,第一个参数是要联表的表名,第二个参数是是否使用左连接。在本例中,我们联接了user表和user_role表,并使用左连接。最后,我们调用UserMapper的selectList方法执行查询操作,并将查询结果保存在userList中。

自定义返回对象

typescript 复制代码
QueryWrapper<User> wrapper = new QueryWrapper<>();wrapper.customizeReturnObject(new CustomizeReturnObject() {    @Override    public void customize(ReturnObjectModel<User> returnObjectModel) {        returnObjectModel.addColumn("full_name", "user.name + ' ' + user.last_name");        returnObjectModel.addColumn("email", "user.email");    }});List<Map<String, Object>> userList = userMapper.selectList(wrapper);

在上面的代码中,我们首先创建了一个QueryWrapper对象,然后使用customizeReturnObject方法进行自定义返回对象。这个方法接受一个CustomizeReturnObject对象作为参数,这个对象实现了customize方法。在customize方法中,我们可以使用returnObjectModel对象来添加自定义的列和表达式。在本例中,我们添加了两个列,一个是用户姓名和姓氏的组合,另一个是用户的电子邮件地址。最后,我们调用UserMapper的selectList方法执行查询操作,并将查询结果保存在userList中。

注:需要使用Mybatis-plus-join,可以参考:github.com/yulichang/m...
相关推荐
光而不耀@lgy9 分钟前
C++初登门槛
linux·开发语言·网络·c++·后端
方圆想当图灵27 分钟前
由 Mybatis 源码畅谈软件设计(七):SQL “染色” 拦截器实战
后端·mybatis·代码规范
毅航1 小时前
MyBatis 事务管理:一文掌握Mybatis事务管理核心逻辑
java·后端·mybatis
我的golang之路果然有问题1 小时前
速成GO访问sql,个人笔记
经验分享·笔记·后端·sql·golang·go·database
柏油1 小时前
MySql InnoDB 事务实现之 undo log 日志
数据库·后端·mysql
写bug写bug3 小时前
Java Streams 中的7个常见错误
java·后端
Luck小吕3 小时前
两天两夜!这个 GB28181 的坑让我差点卸载 VSCode
后端·网络协议
M1A13 小时前
全栈开发必备:Windows安装VS Code全流程
前端·后端·全栈
蜗牛快跑1233 小时前
github 源码阅读神器 deepwiki,自动生成源码架构图和知识库
前端·后端
嘻嘻嘻嘻嘻嘻ys3 小时前
《Vue 3.4响应式超级工厂:Script Setup工程化实战与性能跃迁》
前端·后端