| | |
| | | import org.yeshi.utils.generater.mybatis.ColumnParseUtil; |
| | | import org.yeshi.utils.generater.mybatis.Table; |
| | | import org.yeshi.utils.generater.vo.ExceptionVO; |
| | | import org.yeshi.utils.generater.vo.xmlconfig.dao.DaoData; |
| | | import org.yeshi.utils.generater.vo.xmlconfig.dao.DaoQuery; |
| | | |
| | | import java.lang.annotation.Annotation; |
| | | import java.lang.reflect.Field; |
| | |
| | | private List<DaoQueryColumnData> queryList; |
| | | private String table; |
| | | |
| | | |
| | | public static class Builder { |
| | | |
| | | private ClassInfo baseMapper; |
| | | private Class entity; |
| | | private ClassInfo mapper; |
| | | private DaoData daoData; |
| | | |
| | | public Builder setBaseMapper(ClassInfo baseMapper) { |
| | | this.baseMapper = baseMapper; |
| | |
| | | |
| | | public Builder setMapper(ClassInfo mapper) { |
| | | this.mapper = mapper; |
| | | return this; |
| | | } |
| | | |
| | | public Builder setDaoData(DaoData daoData) { |
| | | this.daoData = daoData; |
| | | return this; |
| | | } |
| | | |
| | |
| | | columlist.add(columData); |
| | | |
| | | |
| | | //获取查询条件 |
| | | for (Annotation a : as) { |
| | | if (a instanceof DaoQueryCondition) { |
| | | if (fd.getType().getSimpleName().equalsIgnoreCase("Date")) { |
| | | daoQueryColumnList.add(new DaoQueryColumnData("max" + StringUtil.firstCharToUpper(columData.getProperty()), columData, fd.getType().getSimpleName(), DaoQueryCondition.QueryType.lt)); |
| | | daoQueryColumnList.add(new DaoQueryColumnData("min" + StringUtil.firstCharToUpper(columData.getProperty()), columData, fd.getType().getSimpleName(), DaoQueryCondition.QueryType.gte)); |
| | | } else { |
| | | daoQueryColumnList.add(new DaoQueryColumnData(columData.getProperty(), columData, fd.getType().getSimpleName(), ((DaoQueryCondition) a).queryType())); |
| | | if (daoData != null) { |
| | | //查询条件从外部传入 |
| | | for (DaoQuery query : daoData.getQueryList()) { |
| | | if (query.getName().equalsIgnoreCase(columData.getProperty())) { |
| | | if (fd.getType().getSimpleName().equalsIgnoreCase("Date")) { |
| | | daoQueryColumnList.add(new DaoQueryColumnData("max" + StringUtil.firstCharToUpper(columData.getProperty()), columData, fd.getType().getSimpleName(), DaoQueryCondition.QueryType.lt)); |
| | | daoQueryColumnList.add(new DaoQueryColumnData("min" + StringUtil.firstCharToUpper(columData.getProperty()), columData, fd.getType().getSimpleName(), DaoQueryCondition.QueryType.gte)); |
| | | } else { |
| | | daoQueryColumnList.add(new DaoQueryColumnData(columData.getProperty(), columData, fd.getType().getSimpleName(), query.getQueryType())); |
| | | } |
| | | } |
| | | break; |
| | | } |
| | | |
| | | } else { |
| | | //获取注解查询条件 |
| | | for (Annotation a : as) { |
| | | if (a instanceof DaoQueryCondition) { |
| | | if (fd.getType().getSimpleName().equalsIgnoreCase("Date")) { |
| | | daoQueryColumnList.add(new DaoQueryColumnData("max" + StringUtil.firstCharToUpper(columData.getProperty()), columData, fd.getType().getSimpleName(), DaoQueryCondition.QueryType.lt)); |
| | | daoQueryColumnList.add(new DaoQueryColumnData("min" + StringUtil.firstCharToUpper(columData.getProperty()), columData, fd.getType().getSimpleName(), DaoQueryCondition.QueryType.gte)); |
| | | } else { |
| | | daoQueryColumnList.add(new DaoQueryColumnData(columData.getProperty(), columData, fd.getType().getSimpleName(), ((DaoQueryCondition) a).queryType())); |
| | | } |
| | | break; |
| | | } |
| | | } |
| | | } |
| | | } |