QueryWrapper 多表
时间: 2023-11-17 21:59:18 浏览: 30
QueryWrapper是MyBatis-Plus中的一个查询构造器,可以用于构建复杂的SQL查询语句。在多表查询中,QueryWrapper可以通过leftJoin方法实现多表关联查询。在引用中的三个例子中,都是通过leftJoin方法将user表和user_role表关联起来,然后根据不同的需求,使用select、distinct、count等方法对查询结果进行处理,最终返回一个IPage、List或Integer类型的结果。
需要注意的是,QueryWrapper中的方法都是链式调用的,可以根据需要灵活组合使用。同时,QueryWrapper还提供了很多其他的方法,如eq、ne、like、in等,可以用于构建更加复杂的查询条件。
相关问题
querywrapper多表查询
QueryWrapper是MyBatis-Plus框架提供的一个查询条件封装器,用于简化多表查询的操作。它可以帮助我们构建复杂的查询条件,并且支持链式调用,使得查询语句更加简洁易读。
使用QueryWrapper进行多表查询的步骤如下:
1. 创建QueryWrapper对象:可以通过new关键字创建QueryWrapper对象,也可以使用QueryWrapper的静态方法进行创建。
2. 设置查询条件:通过QueryWrapper对象的方法,如eq、ne、like等,设置查询条件。
3. 设置关联表:如果需要查询多个表之间的关联数据,可以使用QueryWrapper的join方法设置关联表。
4. 执行查询:通过MyBatis-Plus提供的BaseMapper的selectList或selectPage方法执行查询操作。
下面是一个示例代码,演示了如何使用QueryWrapper进行多表查询:
```java
// 创建QueryWrapper对象
QueryWrapper<User> queryWrapper = new QueryWrapper<>();
// 设置查询条件
queryWrapper.eq("age", 20)
.like("name", "Tom");
// 设置关联表
queryWrapper.join("LEFT JOIN user_role ON user.id = user_role.user_id")
.join("LEFT JOIN role ON user_role.role_id = role.id")
.eq("role.name", "admin");
// 执行查询
List<User> userList = userMapper.selectList(queryWrapper);
```
以上代码中,首先创建了一个QueryWrapper对象,并设置了查询条件和关联表。然后通过userMapper的selectList方法执行查询操作,将符合条件的结果返回给userList。
QueryWrapper多表查询
QueryWrapper是MyBatis Plus提供的一个查询条件构造器,可以用于构建复杂的查询条件。它可以与多表查询一起使用,以实现在多个表之间进行联合查询。
以下是两种使用QueryWrapper实现多表查询的例子:
1. 使用selectPage方法进行分页查询
```java
public IPage<User> getUserListByPage(Integer roleId, Integer pageNum, Integer pageSize) {
QueryWrapper<User> wrapper = new QueryWrapper<>();
wrapper.select("user.*").distinct()
.from("user")
.leftJoin("user_role").on("user.id=user_role.user_id")
.eq("user_role.role_id", roleId);
Page<User> page = new Page<>(pageNum, pageSize);
return userMapper.selectPage(page, wrapper);
}
```
2. 使用selectList方法进行普通查询
```java
public List<User> getUserListByRoleId(Integer roleId) {
QueryWrapper<User> wrapper = new QueryWrapper<>();
wrapper.select("user.*").distinct()
.from("user")
.leftJoin("user_role").on("user.id=user_role.user_id")
.eq("user_role.role_id", roleId);
return userMapper.selectList(wrapper);
}
```