com.github.wz2cool.dynamic.mybatis.mapper.DynamicQueryMapper Maven / Gradle / Ivy
package com.github.wz2cool.dynamic.mybatis.mapper;
import com.github.wz2cool.dynamic.DynamicQuery;
import com.github.wz2cool.dynamic.NormPagingQuery;
import com.github.wz2cool.dynamic.NormPagingQueryWrapper;
import com.github.wz2cool.dynamic.model.NormPagingResult;
import org.apache.ibatis.session.RowBounds;
import tk.mybatis.mapper.annotation.RegisterMapper;
import tk.mybatis.mapper.common.BaseMapper;
import tk.mybatis.mapper.common.special.InsertListMapper;
import java.util.List;
/**
* @author Frank
*/
@RegisterMapper
public interface DynamicQueryMapper extends
BaseMapper,
InsertListMapper,
SelectCountByDynamicQueryMapper,
DeleteByDynamicQueryMapper,
SelectByDynamicQueryMapper,
SelectRowBoundsByDynamicQueryMapper,
UpdateSelectiveByDynamicQueryMapper,
UpdateByDynamicQueryMapper,
SelectMaxByDynamicQueryMapper,
SelectMinByDynamicQueryMapper,
SelectSumByDynamicQueryMapper,
SelectAvgByDynamicQueryMapper,
UpdateByUpdateQueryMapper {
/**
* select by norm paging
*
* @param normPagingQuery norm paging query
* @return norm paging result
*/
default NormPagingResult selectByNormalPaging(NormPagingQuery normPagingQuery) {
NormPagingResult result = new NormPagingResult<>();
int pageNum = normPagingQuery.getPageNum() < 1 ? 1 : normPagingQuery.getPageNum();
int pageSize = normPagingQuery.getPageSize();
int queryPageSize = pageSize + 1;
int offset = (pageNum - 1) * pageSize;
List dataList = selectRowBoundsByDynamicQuery(normPagingQuery.getDynamicQuery(), new RowBounds(offset, queryPageSize));
// 补偿当前页没有需要到上一页
if (normPagingQuery.isAutoBackIfEmpty() && dataList.isEmpty() && pageNum > 1) {
int newPageNum = pageNum - 1;
NormPagingQuery newNormalPagingQuery = NormPagingQuery.createQuery(normPagingQuery.getEntityClass(),
newPageNum, normPagingQuery.getPageSize(),
normPagingQuery.isAutoBackIfEmpty(), normPagingQuery.isCalcTotal());
newNormalPagingQuery.setDistinct(normPagingQuery.isDistinct());
newNormalPagingQuery.setFilters(normPagingQuery.getFilters());
newNormalPagingQuery.setSorts(normPagingQuery.getSorts());
newNormalPagingQuery.setSelectedProperties(normPagingQuery.getSelectedProperties());
newNormalPagingQuery.setIgnoredProperties(normPagingQuery.getIgnoredProperties());
return selectByNormalPaging(newNormalPagingQuery);
}
if (normPagingQuery.isCalcTotal()) {
int totalCount = selectCountByDynamicQuery(normPagingQuery.getDynamicQuery());
int pages = (int) Math.ceil((double) totalCount / pageSize);
result.setTotal(totalCount);
result.setPages(pages);
}
boolean hasNext = dataList.size() > pageSize;
boolean hasPre = pageNum > 1;
result.setHasNextPage(hasNext);
result.setHasPreviousPage(hasPre);
if (dataList.size() > pageSize) {
result.setList(dataList.subList(0, pageSize));
} else {
result.setList(dataList);
}
result.setPageNum(pageNum);
result.setPageSize(normPagingQuery.getPageSize());
return result;
}
default NormPagingResult selectByNormalPaging(NormPagingQueryWrapper> normPagingQueryWrapper) {
NormPagingResult result = new NormPagingResult<>();
int pageNum = normPagingQueryWrapper.getPageNum() < 1 ? 1 : normPagingQueryWrapper.getPageNum();
int pageSize = normPagingQueryWrapper.getPageSize();
int queryPageSize = pageSize + 1;
int offset = (pageNum - 1) * pageSize;
List dataList = selectRowBoundsByDynamicQuery(normPagingQueryWrapper.getSearchQuery(), new RowBounds(offset, queryPageSize));
// 补偿当前页没有需要到上一页
if (normPagingQueryWrapper.isAutoBackIfEmpty() && dataList.isEmpty() && pageNum > 1) {
int newPageNum = pageNum - 1;
NormPagingQueryWrapper> newNormPagingQueryWrapper =
new NormPagingQueryWrapper<>(normPagingQueryWrapper.getSearchQuery());
newNormPagingQueryWrapper.setPageNum(newPageNum);
newNormPagingQueryWrapper.setPageSize(normPagingQueryWrapper.getPageSize());
newNormPagingQueryWrapper.setAutoBackIfEmpty(normPagingQueryWrapper.isAutoBackIfEmpty());
newNormPagingQueryWrapper.setCalcTotal(normPagingQueryWrapper.isCalcTotal());
return selectByNormalPaging(newNormPagingQueryWrapper);
}
if (normPagingQueryWrapper.isCalcTotal()) {
int totalCount = selectCountByDynamicQuery(normPagingQueryWrapper.getSearchQuery());
int pages = (int) Math.ceil((double) totalCount / pageSize);
result.setTotal(totalCount);
result.setPages(pages);
}
boolean hasNext = dataList.size() > pageSize;
boolean hasPre = pageNum > 1;
result.setHasNextPage(hasNext);
result.setHasPreviousPage(hasPre);
if (dataList.size() > pageSize) {
result.setList(dataList.subList(0, pageSize));
} else {
result.setList(dataList);
}
result.setPageNum(pageNum);
result.setPageSize(normPagingQueryWrapper.getPageSize());
return result;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy