com.github.wz2cool.dynamic.mybatis.mapper.provider.GroupedQueryProvider Maven / Gradle / Ivy
package com.github.wz2cool.dynamic.mybatis.mapper.provider;
import com.github.wz2cool.dynamic.GroupedQuery;
import com.github.wz2cool.dynamic.mybatis.QueryHelper;
import com.github.wz2cool.dynamic.mybatis.mapper.helper.BaseEnhancedMapperTemplate;
import com.github.wz2cool.dynamic.mybatis.mapper.helper.GroupedQuerySqlHelper;
import org.apache.commons.lang3.StringUtils;
import org.apache.ibatis.mapping.MappedStatement;
import tk.mybatis.mapper.MapperException;
import tk.mybatis.mapper.mapperhelper.EntityHelper;
import tk.mybatis.mapper.mapperhelper.MapperHelper;
import tk.mybatis.mapper.mapperhelper.SqlHelper;
import java.lang.reflect.ParameterizedType;
import java.lang.reflect.Type;
import java.util.Map;
import static tk.mybatis.mapper.util.MsUtil.getMapperClass;
/**
* @author Frank
**/
@SuppressWarnings("Duplicates")
public class GroupedQueryProvider extends BaseEnhancedMapperTemplate {
private static final QueryHelper QUERY_HELPER = new QueryHelper();
public GroupedQueryProvider(Class> mapperClass, MapperHelper mapperHelper) {
super(mapperClass, mapperHelper);
}
@Override
protected String tableName(Class> entityClass) {
String viewExpression = QUERY_HELPER.getViewExpression(entityClass);
if (StringUtils.isNoneBlank(viewExpression)) {
return viewExpression;
} else {
return super.tableName(entityClass);
}
}
public String selectByGroupedQuery(MappedStatement ms) {
Class> selectClass = getSelectClass(ms);
Class> entityClass = getEntityClass(ms);
setResultType(ms, selectClass);
StringBuilder sql = new StringBuilder();
sql.append(GroupedQuerySqlHelper.getBindFilterParams(ms.getConfiguration().isMapUnderscoreToCamelCase()));
sql.append(GroupedQuerySqlHelper.getFirstClause());
sql.append(String.format("SELECT %s ", GroupedQuerySqlHelper.getHintClause()));
//支持查询指定列
sql.append(GroupedQuerySqlHelper.getSelectColumnsClause());
sql.append(SqlHelper.fromTable(entityClass, tableName(entityClass)));
sql.append(GroupedQuerySqlHelper.getWhereClause());
sql.append(GroupedQuerySqlHelper.getGroupByClause());
sql.append(GroupedQuerySqlHelper.getHavingClause());
sql.append(GroupedQuerySqlHelper.getSortClause());
sql.append(GroupedQuerySqlHelper.getLastClause());
return sql.toString();
}
public String selectCountByGroupedQuery(MappedStatement ms) {
Class> entityClass = getEntityClass(ms);
StringBuilder sql = new StringBuilder();
sql.append(GroupedQuerySqlHelper.getBindFilterParams(ms.getConfiguration().isMapUnderscoreToCamelCase()));
sql.append(GroupedQuerySqlHelper.getFirstClause());
sql.append(String.format("SELECT %s COUNT(*) FROM (", GroupedQuerySqlHelper.getHintClause()));
sql.append(SqlHelper.selectCount(entityClass));
sql.append(SqlHelper.fromTable(entityClass, tableName(entityClass)));
sql.append(GroupedQuerySqlHelper.getWhereClause());
sql.append(GroupedQuerySqlHelper.getGroupByClause());
sql.append(GroupedQuerySqlHelper.getHavingClause());
sql.append(") AS a");
sql.append(GroupedQuerySqlHelper.getLastClause());
return sql.toString();
}
public String selectRowBoundsByGroupedQuery(MappedStatement ms) {
return selectByGroupedQuery(ms);
}
public String selectMaxByGroupedQuery(MappedStatement ms) {
Class> entityClass = getEntityClass(ms);
StringBuilder sql = new StringBuilder();
sql.append(GroupedQuerySqlHelper.getBindFilterParams(ms.getConfiguration().isMapUnderscoreToCamelCase()));
//支持查询指定列
sql.append(GroupedQuerySqlHelper.getFirstClause());
sql.append(GroupedQuerySqlHelper.getSelectMax());
sql.append(SqlHelper.fromTable(entityClass, tableName(entityClass)));
sql.append(GroupedQuerySqlHelper.getWhereClause());
sql.append(GroupedQuerySqlHelper.getGroupByClause());
sql.append(GroupedQuerySqlHelper.getHavingClause());
sql.append(GroupedQuerySqlHelper.getSortClause());
sql.append(GroupedQuerySqlHelper.getLastClause());
return sql.toString();
}
public String selectMaxRowBoundsByGroupedQuery(MappedStatement ms) {
return selectMaxByGroupedQuery(ms);
}
public String selectMinByGroupedQuery(MappedStatement ms) {
Class> entityClass = getEntityClass(ms);
StringBuilder sql = new StringBuilder();
sql.append(GroupedQuerySqlHelper.getBindFilterParams(ms.getConfiguration().isMapUnderscoreToCamelCase()));
//支持查询指定列
sql.append(GroupedQuerySqlHelper.getFirstClause());
sql.append(GroupedQuerySqlHelper.getSelectMin());
sql.append(SqlHelper.fromTable(entityClass, tableName(entityClass)));
sql.append(GroupedQuerySqlHelper.getWhereClause());
sql.append(GroupedQuerySqlHelper.getGroupByClause());
sql.append(GroupedQuerySqlHelper.getHavingClause());
sql.append(GroupedQuerySqlHelper.getSortClause());
sql.append(GroupedQuerySqlHelper.getLastClause());
return sql.toString();
}
public String selectMinRowBoundsByGroupedQuery(MappedStatement ms) {
return selectMinByGroupedQuery(ms);
}
/// region for xml query
public static Map getGroupedQueryParamInternal(
final GroupedQuery groupedQuery,
final boolean isMapUnderscoreToCamelCase) {
return groupedQuery.toQueryParamMap(isMapUnderscoreToCamelCase);
}
// endregion
public Class> getSelectClass(MappedStatement ms) {
String msId = ms.getId() + "_selectClass";
if (entityClassMap.containsKey(msId)) {
return entityClassMap.get(msId);
} else {
Class> mapperClass = getMapperClass(msId);
Type[] types = mapperClass.getGenericInterfaces();
for (Type type : types) {
if (type instanceof ParameterizedType) {
ParameterizedType t = (ParameterizedType) type;
if (t.getRawType() == this.mapperClass || this.mapperClass.isAssignableFrom((Class>) t.getRawType())) {
if (t.getActualTypeArguments().length > 1) {
Class> returnType = (Class>) t.getActualTypeArguments()[t.getActualTypeArguments().length - 1];
//获取该类型后,第一次对该类型进行初始化
EntityHelper.initEntityNameMap(returnType, mapperHelper.getConfig());
entityClassMap.put(msId, returnType);
return returnType;
}
}
}
}
}
throw new MapperException("无法获取 " + msId + " 方法的泛型信息!");
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy