public static <T> Page<T> startPage(PageSortInterface pageSort, Supplier<List<T>> supplier, Object condition) 和public static <T> PageInfo<T> startPage(PageSortInterface pageSort, Supplier<List<T>> supplier, QueryWrapper<T> queryWrapper) 那种更好?为什么?
时间: 2023-10-29 11:07:01 浏览: 122
在使用 MyBatis-Plus 框架时,如果已经熟悉了 `QueryWrapper` 的使用,那么使用 `QueryWrapper` 的方式更好。
使用 `QueryWrapper` 的主要优点是可以方便地构造复杂的查询条件,例如多条件组合查询、排序、分组等,可以更灵活地适应不同的查询需求。
而使用 Object 类型的参数来传递查询条件,则需要在 `supplier` 中进行类型转换和判断,代码可读性和可维护性较差。
因此,综合考虑,使用 `QueryWrapper` 的方式更为推荐。
相关问题
public static <T> PageInfo<T> startPage(PageSortInterface pageSort, Supplier<List<T>> supplier, QueryWrapper<T> queryWrapper) 中的QueryWrapper是什么,有什么作用?
`QueryWrapper` 是 MyBatis-Plus 框架提供的一个查询条件构造器,用于方便地构造 SQL 查询条件。
在 `startPage` 方法中增加 `QueryWrapper` 参数后,可以使用它来构造查询条件,例如:
```
public static <T> PageInfo<T> startPage(PageSortInterface pageSort, Supplier<List<T>> supplier, QueryWrapper<T> queryWrapper) {
PageHelper.startPage(pageSort.getPageNum(), pageSort.getPageSize(), pageSort.getSort() + " " + pageSort.getOrder());
List<T> list = supplier.get(queryWrapper);
PageInfo<T> pageInfo = new PageInfo<>(list);
return pageInfo;
}
```
在 `supplier` 中接收 `QueryWrapper` 参数,例如:
```
public List<User> getUsersByCondition(QueryWrapper<User> queryWrapper) {
return userDao.selectList(queryWrapper);
}
```
这样就可以使用 `QueryWrapper` 构造查询条件,实现更为灵活的分页查询。
请示例一个公用的PageHelper分页查询,比如下面这个:public static <T> Page<T> startPage(PageSortInterface pageSort, Supplier<List<T>> supplier, Object queryWrapper) { PageHelper.startPage(pageSort.getPageNum(), pageSort.getPageSize(), pageSort.getSort() + " " + pageSort.getOrder()); List<T> list = supplier.get(); Page<T> page = new Page<>(); return (Page<T>) list; }
好的,以下是一个使用PageHelper进行分页查询的示例代码:
```java
public static <T> PageInfo<T> pageQuery(PageQueryInterface pageQuery, Supplier<List<T>> supplier) {
PageHelper.startPage(pageQuery.getPageNum(), pageQuery.getPageSize());
List<T> list = supplier.get();
return new PageInfo<>(list);
}
```
这个方法接受一个实现了PageQueryInterface接口的对象和一个数据提供者supplier作为参数,其中PageQueryInterface定义了分页查询所需要的参数,例如页码、每页大小等等。在方法内部,我们使用PageHelper.startPage方法来启动分页,然后调用supplier来获取数据,并将得到的结果封装成PageInfo对象返回。
需要注意的是,这里我们使用了PageInfo类来封装分页查询结果,它不仅包括查询结果本身,还包括了分页信息,例如总页数、总记录数等等。
阅读全文