|
@@ -1,540 +0,0 @@
|
|
|
-/*
|
|
|
- * Copyright (c) 2011-2020, hubin (jobob@qq.com).
|
|
|
- * <p>
|
|
|
- * Licensed under the Apache License, Version 2.0 (the "License"); you may not
|
|
|
- * use this file except in compliance with the License. You may obtain a copy of
|
|
|
- * the License at
|
|
|
- * <p>
|
|
|
- * http://www.apache.org/licenses/LICENSE-2.0
|
|
|
- * <p>
|
|
|
- * Unless required by applicable law or agreed to in writing, software
|
|
|
- * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
|
- * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
|
- * License for the specific language governing permissions and limitations under
|
|
|
- * the License.
|
|
|
- */
|
|
|
-package com.baomidou.mybatisplus.core.injector.methods;
|
|
|
-
|
|
|
-import java.lang.reflect.ParameterizedType;
|
|
|
-import java.lang.reflect.Type;
|
|
|
-import java.lang.reflect.TypeVariable;
|
|
|
-import java.lang.reflect.WildcardType;
|
|
|
-import java.util.Iterator;
|
|
|
-import java.util.List;
|
|
|
-
|
|
|
-import org.apache.ibatis.builder.MapperBuilderAssistant;
|
|
|
-import org.apache.ibatis.executor.keygen.KeyGenerator;
|
|
|
-import org.apache.ibatis.executor.keygen.NoKeyGenerator;
|
|
|
-import org.apache.ibatis.mapping.MappedStatement;
|
|
|
-import org.apache.ibatis.mapping.SqlCommandType;
|
|
|
-import org.apache.ibatis.mapping.SqlSource;
|
|
|
-import org.apache.ibatis.mapping.StatementType;
|
|
|
-import org.apache.ibatis.scripting.LanguageDriver;
|
|
|
-import org.apache.ibatis.session.Configuration;
|
|
|
-
|
|
|
-import com.baomidou.mybatisplus.annotation.FieldFill;
|
|
|
-import com.baomidou.mybatisplus.annotation.FieldStrategy;
|
|
|
-import com.baomidou.mybatisplus.core.metadata.GlobalConfiguration;
|
|
|
-import com.baomidou.mybatisplus.core.metadata.TableFieldInfo;
|
|
|
-import com.baomidou.mybatisplus.core.metadata.TableInfo;
|
|
|
-import com.baomidou.mybatisplus.core.toolkit.ArrayUtils;
|
|
|
-import com.baomidou.mybatisplus.core.toolkit.CollectionUtils;
|
|
|
-import com.baomidou.mybatisplus.core.toolkit.GlobalConfigUtils;
|
|
|
-import com.baomidou.mybatisplus.core.toolkit.StringUtils;
|
|
|
-import com.baomidou.mybatisplus.core.toolkit.TableInfoHelper;
|
|
|
-
|
|
|
-/**
|
|
|
- * <p>
|
|
|
- * 抽象的注入方法类
|
|
|
- * </p>
|
|
|
- *
|
|
|
- * @author hubin
|
|
|
- * @since 2018-04-06
|
|
|
- */
|
|
|
-public abstract class AbstractMethod {
|
|
|
-
|
|
|
- protected Configuration configuration;
|
|
|
- protected LanguageDriver languageDriver;
|
|
|
- protected MapperBuilderAssistant builderAssistant;
|
|
|
-
|
|
|
-
|
|
|
- /**
|
|
|
- * 注入自定义方法
|
|
|
- */
|
|
|
- public void inject(MapperBuilderAssistant builderAssistant, Class<?> mapperClass) {
|
|
|
- this.configuration = builderAssistant.getConfiguration();
|
|
|
- this.builderAssistant = builderAssistant;
|
|
|
- this.languageDriver = configuration.getDefaultScriptingLanguageInstance();
|
|
|
- Class<?> modelClass = extractModelClass(mapperClass);
|
|
|
- if (null != modelClass) {
|
|
|
- // 注入自定义方法
|
|
|
- TableInfo tableInfo = TableInfoHelper.initTableInfo(builderAssistant, modelClass);
|
|
|
- this.injectMappedStatement(mapperClass, modelClass, tableInfo);
|
|
|
- }
|
|
|
- }
|
|
|
-
|
|
|
-
|
|
|
- /**
|
|
|
- * 提取泛型模型,多泛型的时候请将泛型T放在第一位
|
|
|
- *
|
|
|
- * @param mapperClass
|
|
|
- * @return
|
|
|
- */
|
|
|
- protected Class<?> extractModelClass(Class<?> mapperClass) {
|
|
|
- Type[] types = mapperClass.getGenericInterfaces();
|
|
|
- ParameterizedType target = null;
|
|
|
- for (Type type : types) {
|
|
|
- if (type instanceof ParameterizedType) {
|
|
|
- Type[] typeArray = ((ParameterizedType) type).getActualTypeArguments();
|
|
|
- if (ArrayUtils.isNotEmpty(typeArray)) {
|
|
|
- for (Type t : typeArray) {
|
|
|
- if (t instanceof TypeVariable || t instanceof WildcardType) {
|
|
|
- target = null;
|
|
|
- break;
|
|
|
- } else {
|
|
|
- target = (ParameterizedType) type;
|
|
|
- break;
|
|
|
- }
|
|
|
- }
|
|
|
- }
|
|
|
- break;
|
|
|
- }
|
|
|
- }
|
|
|
- return target == null ? null : (Class<?>) target.getActualTypeArguments()[0];
|
|
|
- }
|
|
|
-
|
|
|
-
|
|
|
- /**
|
|
|
- * 是否已经存在MappedStatement
|
|
|
- *
|
|
|
- * @param mappedStatement
|
|
|
- * @return
|
|
|
- */
|
|
|
- private boolean hasMappedStatement(String mappedStatement) {
|
|
|
- return configuration.hasStatement(mappedStatement, false);
|
|
|
- }
|
|
|
-
|
|
|
-
|
|
|
- /**
|
|
|
- * <p>
|
|
|
- * SQL 更新 set 语句
|
|
|
- * </p>
|
|
|
- *
|
|
|
- * @param selective 是否选择判断
|
|
|
- * @param table 表信息
|
|
|
- * @param prefix 前缀
|
|
|
- * @return
|
|
|
- */
|
|
|
- protected String sqlSet(boolean selective, TableInfo table, String prefix) {
|
|
|
- StringBuilder set = new StringBuilder();
|
|
|
- set.append("<trim prefix=\"SET\" suffixOverrides=\",\">");
|
|
|
-
|
|
|
- // 是否 IF 标签判断
|
|
|
- boolean ifTag;
|
|
|
- List<TableFieldInfo> fieldList = table.getFieldList();
|
|
|
- for (TableFieldInfo fieldInfo : fieldList) {
|
|
|
- // 判断是否更新忽略,在FieldIgnore,UPDATE,INSERT_UPDATE设置为false
|
|
|
- ifTag = !(FieldFill.UPDATE == fieldInfo.getFieldFill()
|
|
|
- || FieldFill.INSERT_UPDATE == fieldInfo.getFieldFill());
|
|
|
- if (selective && ifTag) {
|
|
|
- if (StringUtils.isNotEmpty(fieldInfo.getUpdate())) {
|
|
|
- set.append(fieldInfo.getColumn()).append("=");
|
|
|
- set.append(String.format(fieldInfo.getUpdate(), fieldInfo.getColumn())).append(",");
|
|
|
- } else {
|
|
|
- set.append(convertIfTag(true, fieldInfo, prefix, false));
|
|
|
- set.append(fieldInfo.getColumn()).append("=#{");
|
|
|
- if (null != prefix) {
|
|
|
- set.append(prefix);
|
|
|
- }
|
|
|
- set.append(fieldInfo.getEl()).append("},");
|
|
|
- set.append(convertIfTag(true, fieldInfo, null, true));
|
|
|
- }
|
|
|
- } else if (FieldFill.INSERT != fieldInfo.getFieldFill()) {
|
|
|
- // 排除填充注解字段
|
|
|
- set.append(fieldInfo.getColumn()).append("=#{");
|
|
|
- if (null != prefix) {
|
|
|
- set.append(prefix);
|
|
|
- }
|
|
|
- set.append(fieldInfo.getEl()).append("},");
|
|
|
- }
|
|
|
- }
|
|
|
- set.append("\n</trim>");
|
|
|
- return set.toString();
|
|
|
- }
|
|
|
-
|
|
|
-
|
|
|
- /**
|
|
|
- * <p>
|
|
|
- * 获取需要转义的SQL字段
|
|
|
- * </p>
|
|
|
- *
|
|
|
- * @param convertStr
|
|
|
- * @return
|
|
|
- */
|
|
|
- protected String sqlWordConvert(String convertStr) {
|
|
|
-// GlobalConfiguration globalConfig = GlobalConfigUtils.getGlobalConfig(configuration);
|
|
|
-// return SqlReservedWords.convert(globalConfig, convertStr);
|
|
|
- //TODO: 3.0
|
|
|
- // 定义一个interface, 通过GlobalConfiguration获取
|
|
|
- return convertStr;
|
|
|
- }
|
|
|
-
|
|
|
- /**
|
|
|
- * <p>
|
|
|
- * SQL 查询所有表字段
|
|
|
- * </p>
|
|
|
- *
|
|
|
- * @param table
|
|
|
- * @param entityWrapper 是否为包装类型查询
|
|
|
- * @return
|
|
|
- */
|
|
|
- protected String sqlSelectColumns(TableInfo table, boolean entityWrapper) {
|
|
|
- StringBuilder columns = new StringBuilder();
|
|
|
- if (null != table.getResultMap()) {
|
|
|
- /*
|
|
|
- * 存在 resultMap 映射返回
|
|
|
- */
|
|
|
- if (entityWrapper) {
|
|
|
- columns.append("<choose><when test=\"ew != null and ew.sqlSelect != null\">${ew.sqlSelect}</when><otherwise>");
|
|
|
- }
|
|
|
- columns.append("*");
|
|
|
- if (entityWrapper) {
|
|
|
- columns.append("</otherwise></choose>");
|
|
|
- }
|
|
|
- } else {
|
|
|
- /*
|
|
|
- * 普通查询
|
|
|
- */
|
|
|
- if (entityWrapper) {
|
|
|
- columns.append("<choose><when test=\"ew != null and ew.sqlSelect != null\">${ew.sqlSelect}</when><otherwise>");
|
|
|
- }
|
|
|
- List<TableFieldInfo> fieldList = table.getFieldList();
|
|
|
- int size = 0;
|
|
|
- if (null != fieldList) {
|
|
|
- size = fieldList.size();
|
|
|
- }
|
|
|
-
|
|
|
- // 主键处理
|
|
|
- if (StringUtils.isNotEmpty(table.getKeyProperty())) {
|
|
|
- if (table.isKeyRelated()) {
|
|
|
- columns.append(table.getKeyColumn()).append(" AS ").append(sqlWordConvert(table.getKeyProperty()));
|
|
|
- } else {
|
|
|
- columns.append(sqlWordConvert(table.getKeyProperty()));
|
|
|
- }
|
|
|
- if (size >= 1) {
|
|
|
- // 判断其余字段是否存在
|
|
|
- columns.append(",");
|
|
|
- }
|
|
|
- }
|
|
|
-
|
|
|
- if (size >= 1) {
|
|
|
- // 字段处理
|
|
|
- int i = 0;
|
|
|
- Iterator<TableFieldInfo> iterator = fieldList.iterator();
|
|
|
- while (iterator.hasNext()) {
|
|
|
- TableFieldInfo fieldInfo = iterator.next();
|
|
|
- // 匹配转换内容
|
|
|
- String wordConvert = sqlWordConvert(fieldInfo.getProperty());
|
|
|
- if (fieldInfo.getColumn().equals(wordConvert)) {
|
|
|
- columns.append(wordConvert);
|
|
|
- } else {
|
|
|
- // 字段属性不一致
|
|
|
- columns.append(fieldInfo.getColumn());
|
|
|
- columns.append(" AS ").append(wordConvert);
|
|
|
- }
|
|
|
- if (i + 1 < size) {
|
|
|
- columns.append(",");
|
|
|
- }
|
|
|
- i++;
|
|
|
- }
|
|
|
- }
|
|
|
- if (entityWrapper) {
|
|
|
- columns.append("</otherwise></choose>");
|
|
|
- }
|
|
|
- }
|
|
|
-
|
|
|
- /*
|
|
|
- * 返回所有查询字段内容
|
|
|
- */
|
|
|
- return columns.toString();
|
|
|
- }
|
|
|
-
|
|
|
- /**
|
|
|
- * <p>
|
|
|
- * SQL 设置selectObj sqlselect
|
|
|
- * </p>
|
|
|
- *
|
|
|
- * @param table 是否为包装类型查询
|
|
|
- * @return
|
|
|
- */
|
|
|
- protected String sqlSelectObjsColumns(TableInfo table) {
|
|
|
- StringBuilder columns = new StringBuilder();
|
|
|
- /*
|
|
|
- * 普通查询
|
|
|
- */
|
|
|
- columns.append("<choose><when test=\"ew != null and ew.sqlSelect != null\">${ew.sqlSelect}</when><otherwise>");
|
|
|
- // 主键处理
|
|
|
- if (StringUtils.isNotEmpty(table.getKeyProperty())) {
|
|
|
- if (table.isKeyRelated()) {
|
|
|
- columns.append(table.getKeyColumn()).append(" AS ").append(sqlWordConvert(table.getKeyProperty()));
|
|
|
- } else {
|
|
|
- columns.append(sqlWordConvert(table.getKeyProperty()));
|
|
|
- }
|
|
|
- } else {
|
|
|
- // 表字段处理
|
|
|
- List<TableFieldInfo> fieldList = table.getFieldList();
|
|
|
- if (CollectionUtils.isNotEmpty(fieldList)) {
|
|
|
- TableFieldInfo fieldInfo = fieldList.get(0);
|
|
|
- // 匹配转换内容
|
|
|
- String wordConvert = sqlWordConvert(fieldInfo.getProperty());
|
|
|
- if (fieldInfo.getColumn().equals(wordConvert)) {
|
|
|
- columns.append(wordConvert);
|
|
|
- } else {
|
|
|
- // 字段属性不一致
|
|
|
- columns.append(fieldInfo.getColumn());
|
|
|
- columns.append(" AS ").append(wordConvert);
|
|
|
- }
|
|
|
- }
|
|
|
- }
|
|
|
- columns.append("</otherwise></choose>");
|
|
|
- return columns.toString();
|
|
|
- }
|
|
|
-
|
|
|
- /**
|
|
|
- * <p>
|
|
|
- * SQL 查询条件
|
|
|
- * </p>
|
|
|
- */
|
|
|
- protected String sqlWhere(TableInfo table) {
|
|
|
- StringBuilder where = new StringBuilder();
|
|
|
- where.append("\n<where>");
|
|
|
- if (StringUtils.isNotEmpty(table.getKeyProperty())) {
|
|
|
- where.append("\n<if test=\"ew.").append(table.getKeyProperty()).append("!=null\">\n");
|
|
|
- where.append(table.getKeyColumn()).append("=#{ew.").append(table.getKeyProperty()).append("}");
|
|
|
- where.append("\n</if>");
|
|
|
- }
|
|
|
- List<TableFieldInfo> fieldList = table.getFieldList();
|
|
|
- for (TableFieldInfo fieldInfo : fieldList) {
|
|
|
- where.append(convertIfTag(fieldInfo, "ew.", false));
|
|
|
- where.append(" AND ").append(this.sqlCondition(fieldInfo.getCondition(),
|
|
|
- fieldInfo.getColumn(), "ew." + fieldInfo.getEl()));
|
|
|
- where.append(convertIfTag(fieldInfo, true));
|
|
|
- }
|
|
|
- where.append("\n</where>");
|
|
|
- return where.toString();
|
|
|
- }
|
|
|
-
|
|
|
- /**
|
|
|
- * <p>
|
|
|
- * SQL map 查询条件
|
|
|
- * </p>
|
|
|
- */
|
|
|
- protected String sqlWhereByMap(TableInfo table) {
|
|
|
- StringBuilder where = new StringBuilder();
|
|
|
- where.append("\n<if test=\"cm!=null and !cm.isEmpty\">");
|
|
|
- where.append("\n<where>");
|
|
|
- where.append("\n<foreach collection=\"cm.keys\" item=\"k\" separator=\"AND\">");
|
|
|
- where.append("\n<if test=\"cm[k] != null\">");
|
|
|
- //TODO: 3.0
|
|
|
- where.append("\n").append(this.getGlobalConfig().getReservedWordsHandler().convert(getGlobalConfig(), "${k}")).append(" = #{cm[${k}]}");
|
|
|
-// where.append("\n").append(SqlReservedWords.convert(getGlobalConfig(), "${k}")).append(" = #{cm[${k}]}");
|
|
|
- where.append("\n</if>");
|
|
|
- where.append("\n</foreach>");
|
|
|
- where.append("\n</where>");
|
|
|
- where.append("\n</if>");
|
|
|
- return where.toString();
|
|
|
- }
|
|
|
-
|
|
|
- /**
|
|
|
- * <p>
|
|
|
- * IF 条件转换方法
|
|
|
- * </p>
|
|
|
- *
|
|
|
- * @param ignored 允许忽略
|
|
|
- * @param fieldInfo 字段信息
|
|
|
- * @param prefix 条件前缀
|
|
|
- * @param close 是否闭合标签
|
|
|
- * @return
|
|
|
- */
|
|
|
- protected String convertIfTag(boolean ignored, TableFieldInfo fieldInfo, String prefix, boolean close) {
|
|
|
- /** 忽略策略 */
|
|
|
- FieldStrategy fieldStrategy = fieldInfo.getFieldStrategy();
|
|
|
- if (fieldStrategy == FieldStrategy.IGNORED) {
|
|
|
- if (ignored) {
|
|
|
- return "";
|
|
|
- }
|
|
|
- // 查询策略,使用全局策略
|
|
|
- fieldStrategy = this.getGlobalConfig().getFieldStrategy();
|
|
|
- }
|
|
|
-
|
|
|
- // 关闭标签
|
|
|
- if (close) {
|
|
|
- return "</if>";
|
|
|
- }
|
|
|
-
|
|
|
- /** 前缀处理 */
|
|
|
- String property = fieldInfo.getProperty();
|
|
|
- Class propertyType = fieldInfo.getPropertyType();
|
|
|
- property = StringUtils.removeIsPrefixIfBoolean(property, propertyType);
|
|
|
- if (null != prefix) {
|
|
|
- property = prefix + property;
|
|
|
- }
|
|
|
- // 验证逻辑
|
|
|
- if (fieldStrategy == FieldStrategy.NOT_EMPTY) {
|
|
|
- if (StringUtils.isCharSequence(propertyType)) {
|
|
|
- return String.format("\n\t<if test=\"%s!=null and %s!=''\">", property, property);
|
|
|
- } else {
|
|
|
- return String.format("\n\t<if test=\"%s!=null \">", property);
|
|
|
- }
|
|
|
- } else {
|
|
|
- // FieldStrategy.NOT_NULL
|
|
|
- return String.format("\n\t<if test=\"%s!=null\">", property);
|
|
|
- }
|
|
|
- }
|
|
|
-
|
|
|
-
|
|
|
- protected String convertIfTagIgnored(TableFieldInfo fieldInfo, boolean close) {
|
|
|
- return convertIfTag(true, fieldInfo, null, close);
|
|
|
- }
|
|
|
-
|
|
|
-
|
|
|
- protected String convertIfTag(TableFieldInfo fieldInfo, String prefix, boolean close) {
|
|
|
- return convertIfTag(false, fieldInfo, prefix, close);
|
|
|
- }
|
|
|
-
|
|
|
-
|
|
|
- protected String convertIfTag(TableFieldInfo fieldInfo, boolean close) {
|
|
|
- return convertIfTag(fieldInfo, null, close);
|
|
|
- }
|
|
|
-
|
|
|
-
|
|
|
- /**
|
|
|
- * <p>
|
|
|
- * Sql 运算条件
|
|
|
- * </p>
|
|
|
- */
|
|
|
- protected String sqlCondition(String condition, String column, String property) {
|
|
|
- return String.format(condition, column, property);
|
|
|
- }
|
|
|
-
|
|
|
-
|
|
|
- /**
|
|
|
- * <p>
|
|
|
- * EntityWrapper方式获取select where
|
|
|
- * </p>
|
|
|
- *
|
|
|
- * @param table 表信息
|
|
|
- * @return String
|
|
|
- */
|
|
|
- protected String sqlWhereEntityWrapper(TableInfo table) {
|
|
|
- StringBuilder where = new StringBuilder(128);
|
|
|
- where.append("\n<where>");
|
|
|
- where.append("\n<if test=\"ew!=null\">");
|
|
|
- where.append("\n<if test=\"ew.entity!=null\">");
|
|
|
- if (StringUtils.isNotEmpty(table.getKeyProperty())) {
|
|
|
- where.append("\n<if test=\"ew.entity.").append(table.getKeyProperty()).append("!=null\">\n");
|
|
|
- where.append(table.getKeyColumn()).append("=#{ew.entity.").append(table.getKeyProperty()).append("}");
|
|
|
- where.append("\n</if>");
|
|
|
- }
|
|
|
- List<TableFieldInfo> fieldList = table.getFieldList();
|
|
|
- for (TableFieldInfo fieldInfo : fieldList) {
|
|
|
- where.append(convertIfTag(fieldInfo, "ew.entity.", false));
|
|
|
- where.append(" AND ").append(this.sqlCondition(fieldInfo.getCondition(),
|
|
|
- fieldInfo.getColumn(), "ew.entity." + fieldInfo.getEl()));
|
|
|
- where.append(convertIfTag(fieldInfo, true));
|
|
|
- }
|
|
|
- where.append("\n</if>");
|
|
|
- where.append("\n<if test=\"ew!=null and ew.sqlSegment!=null and ew.notEmptyOfWhere\">\n${ew.sqlSegment}\n</if>");
|
|
|
- where.append("\n</if>");
|
|
|
- where.append("\n</where>");
|
|
|
- where.append("\n<if test=\"ew!=null and ew.sqlSegment!=null and ew.emptyOfWhere\">\n${ew.sqlSegment}\n</if>");
|
|
|
- return where.toString();
|
|
|
- }
|
|
|
-
|
|
|
-
|
|
|
- /**
|
|
|
- * 查询
|
|
|
- */
|
|
|
- protected MappedStatement addSelectMappedStatement(Class<?> mapperClass, String id, SqlSource sqlSource, Class<?> resultType,
|
|
|
- TableInfo table) {
|
|
|
- if (null != table) {
|
|
|
- String resultMap = table.getResultMap();
|
|
|
- if (null != resultMap) {
|
|
|
- /** 返回 resultMap 映射结果集 */
|
|
|
- return this.addMappedStatement(mapperClass, id, sqlSource, SqlCommandType.SELECT, null, resultMap, null,
|
|
|
- new NoKeyGenerator(), null, null);
|
|
|
- }
|
|
|
- }
|
|
|
-
|
|
|
- /** 普通查询 */
|
|
|
- return this.addMappedStatement(mapperClass, id, sqlSource, SqlCommandType.SELECT, null, null, resultType,
|
|
|
- new NoKeyGenerator(), null, null);
|
|
|
- }
|
|
|
-
|
|
|
-
|
|
|
- /**
|
|
|
- * 插入
|
|
|
- */
|
|
|
- protected MappedStatement addInsertMappedStatement(Class<?> mapperClass, Class<?> modelClass, String id, SqlSource sqlSource,
|
|
|
- KeyGenerator keyGenerator, String keyProperty, String keyColumn) {
|
|
|
- return this.addMappedStatement(mapperClass, id, sqlSource, SqlCommandType.INSERT, modelClass, null, Integer.class,
|
|
|
- keyGenerator, keyProperty, keyColumn);
|
|
|
- }
|
|
|
-
|
|
|
-
|
|
|
- /**
|
|
|
- * 删除
|
|
|
- */
|
|
|
- protected MappedStatement addDeleteMappedStatement(Class<?> mapperClass, String id, SqlSource sqlSource) {
|
|
|
- return this.addMappedStatement(mapperClass, id, sqlSource, SqlCommandType.DELETE, null, null, Integer.class,
|
|
|
- new NoKeyGenerator(), null, null);
|
|
|
- }
|
|
|
-
|
|
|
-
|
|
|
- /**
|
|
|
- * 更新
|
|
|
- */
|
|
|
- public MappedStatement addUpdateMappedStatement(Class<?> mapperClass, Class<?> modelClass, String id, SqlSource sqlSource) {
|
|
|
- return this.addMappedStatement(mapperClass, id, sqlSource, SqlCommandType.UPDATE, modelClass, null, Integer.class,
|
|
|
- new NoKeyGenerator(), null, null);
|
|
|
- }
|
|
|
-
|
|
|
-
|
|
|
- /**
|
|
|
- * 添加 MappedStatement 到 Mybatis 容器
|
|
|
- */
|
|
|
- protected MappedStatement addMappedStatement(Class<?> mapperClass, String id, SqlSource sqlSource,
|
|
|
- SqlCommandType sqlCommandType, Class<?> parameterClass, String resultMap, Class<?> resultType,
|
|
|
- KeyGenerator keyGenerator, String keyProperty, String keyColumn) {
|
|
|
- String statementName = mapperClass.getName() + "." + id;
|
|
|
- if (hasMappedStatement(statementName)) {
|
|
|
- System.err.println("{" + statementName + "} Has been loaded by XML or SqlProvider, ignoring the injection of the SQL.");
|
|
|
- return null;
|
|
|
- }
|
|
|
- /** 缓存逻辑处理 */
|
|
|
- boolean isSelect = false;
|
|
|
- if (sqlCommandType == SqlCommandType.SELECT) {
|
|
|
- isSelect = true;
|
|
|
- }
|
|
|
- return builderAssistant.addMappedStatement(id, sqlSource, StatementType.PREPARED, sqlCommandType, null, null, null,
|
|
|
- parameterClass, resultMap, resultType, null, !isSelect, isSelect, false, keyGenerator, keyProperty, keyColumn,
|
|
|
- configuration.getDatabaseId(), languageDriver, null);
|
|
|
- }
|
|
|
-
|
|
|
-
|
|
|
- /**
|
|
|
- * <p>
|
|
|
- * 全局配置
|
|
|
- * </p>
|
|
|
- */
|
|
|
- protected GlobalConfiguration getGlobalConfig() {
|
|
|
- return GlobalConfigUtils.getGlobalConfig(configuration);
|
|
|
- }
|
|
|
-
|
|
|
-
|
|
|
- /**
|
|
|
- * 注入自定义 MappedStatement
|
|
|
- */
|
|
|
- abstract MappedStatement injectMappedStatement(Class<?> mapperClass, Class<?> modelClass, TableInfo tableInfo);
|
|
|
-
|
|
|
-}
|