All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.github.wz2cool.dynamic.mybatis.mapper.DynamicQueryMapper Maven / Gradle / Ivy

There is a newer version: 3.2.32
Show newest version
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