LambdaQueryWrapper 多表条件查询
时间: 2023-03-27 17:05:10 浏览: 595
LambdaQueryWrapper 是 MyBatis-Plus 框架中的一个查询条件构造器,可以用于多表条件查询。通过 LambdaQueryWrapper 可以方便地构建多表关联查询的条件,例如联表查询、子查询等。同时,LambdaQueryWrapper 还支持链式调用,可以更加灵活地构建查询条件。
相关问题
LambdaQueryWrapper多表分页查询
LambdaQueryWrapper 是 MyBatis-Plus 中用于构建 SQL 查询语句的工具类。要进行多表分页查询,可以使用 LambdaQueryWrapper 的 join 方法来进行多表连接查询,然后使用 Page 对象进行分页。以下是一个示例代码:
```java
Page<User> page = new Page<>(1, 10);
LambdaQueryWrapper<User> wrapper = new LambdaQueryWrapper<>();
wrapper.eq(User::getStatus, 1)
.join(UserRole.class, UserRole::getUserId, User::getId)
.eq(UserRole::getRoleId, 2)
.select(User::getId, User::getUsername, User::getEmail);
IPage<User> userPage = userService.page(page, wrapper);
```
这个例子中,我们查询了用户表和用户角色表,条件是用户状态为 1,角色为 2。我们使用的是 LambdaQueryWrapper 的 join 方法来进行多表连接查询,连接条件是用户表的 id 字段等于用户角色表的 user_id 字段。然后我们使用 Page 对象进行分页查询,第一个参数是当前页码,第二个参数是每页的数据条数。最后我们调用 userService 的 page 方法进行查询,返回的是一个 IPage 对象,其中包含了查询结果和分页信息。
LambdaQueryWrapper 多表查询内连接条件查询
LambdaQueryWrapper 是 MyBatis-Plus 中的一个查询条件构造器,可以用于构造复杂的查询条件。多表查询内连接条件查询可以通过 LambdaQueryWrapper 的 join 方法来实现。
假设有两个表 A 和 B,需要查询它们的内连接结果,并且需要满足 A 表的某个字段等于某个值,B 表的某个字段也等于某个值,可以按照下面的方式构造查询条件:
```
LambdaQueryWrapper wrapper = new LambdaQueryWrapper();
wrapper.eq(A::getField, value)
.eq(B::getField, value)
.last("INNER JOIN B ON A.id = B.a_id");
```
其中,eq 方法用于添加等于条件,getField 是指实体类中对应字段的 getter 方法,value 是需要查询的值。last 方法用于添加 SQL 的末尾部分,用于添加 JOIN 条件。
这样就可以通过 LambdaQueryWrapper 实现多表查询内连接条件查询了。
阅读全文