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

tk.mybatis.mapper.entity.Config Maven / Gradle / Ivy

The newest version!
/*
 * The MIT License (MIT)
 *
 * Copyright (c) 2014-2017 [email protected]
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 * of this software and associated documentation files (the "Software"), to deal
 * in the Software without restriction, including without limitation the rights
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 * copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in
 * all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
 * THE SOFTWARE.
 */

package tk.mybatis.mapper.entity;

import tk.mybatis.mapper.MapperException;
import tk.mybatis.mapper.code.IdentityDialect;
import tk.mybatis.mapper.code.Style;
import tk.mybatis.mapper.mapperhelper.resolve.EntityResolve;
import tk.mybatis.mapper.util.SimpleTypeUtil;
import tk.mybatis.mapper.util.StringUtil;

import java.util.ArrayList;
import java.util.List;
import java.util.Properties;

/**
 * 通用Mapper属性配置
 *
 * @author liuzh
 */
public class Config {
    public static final String PREFIX = "mapper";

    private List mappers = new ArrayList();
    private String IDENTITY;
    private boolean BEFORE;
    private String seqFormat;
    private String catalog;
    private String schema;
    //校验调用Example方法时,Example(entityClass)和Mapper是否一致
    private boolean checkExampleEntityClass;
    //使用简单类型
    //3.5.0 后默认值改为 true
    private boolean useSimpleType = true;
    /**
     * @since 3.5.0
     */
    private boolean enumAsSimpleType;
    /**
     * 是否支持方法上的注解,默认false
     */
    private boolean enableMethodAnnotation;
    /**
     * 对于一般的getAllIfColumnNode,是否判断!='',默认不判断
     */
    private boolean notEmpty;
    /**
     * 字段转换风格,默认驼峰转下划线
     */
    private Style style;
    /**
     * 处理关键字,默认空,mysql可以设置为 `{0}`, sqlserver 为 [{0}],{0} 代表的列名
     */
    private String wrapKeyword = "";
    /**
     * 配置解析器
     */
    private Class resolveClass;
    /**
     * 安全删除,开启后,不允许删全表,如 delete from table
     */
    private boolean safeDelete;
    /**
     * 安全更新,开启后,不允许更新全表,如 update table set xx=?
     */
    private boolean safeUpdate;
    /**
     * 是否设置 javaType
     */
    private boolean useJavaType;
    /**
     * 是否自动处理 Mapper 接口中其他手写指定 resultType 的返回结果类型为 resultMap
     */
    private boolean enableBaseResultMapFlag;

    public String getCatalog() {
        return catalog;
    }

    /**
     * 设置全局的catalog,默认为空,如果设置了值,操作表时的sql会是catalog.tablename
     *
     * @param catalog
     */
    public void setCatalog(String catalog) {
        this.catalog = catalog;
    }

    /**
     * 获取主键自增回写SQL
     *
     * @return
     */
    public String getIDENTITY() {
        if (StringUtil.isNotEmpty(this.IDENTITY)) {
            return this.IDENTITY;
        }
        //针对mysql的默认值
        return IdentityDialect.MYSQL.getIdentityRetrievalStatement();
    }

    /**
     * 主键自增回写方法,默认值MYSQL,详细说明请看文档
     *
     * @param IDENTITY
     */
    public void setIDENTITY(String IDENTITY) {
        IdentityDialect identityDialect = IdentityDialect.getDatabaseDialect(IDENTITY);
        if (identityDialect != null) {
            this.IDENTITY = identityDialect.getIdentityRetrievalStatement();
        } else {
            this.IDENTITY = IDENTITY;
        }
    }

    /**
     * 获取表前缀,带catalog或schema
     *
     * @return
     */
    public String getPrefix() {
        if (StringUtil.isNotEmpty(this.catalog)) {
            return this.catalog;
        }
        if (StringUtil.isNotEmpty(this.schema)) {
            return this.schema;
        }
        return "";
    }

    public String getSchema() {
        return schema;
    }

    /**
     * 设置全局的schema,默认为空,如果设置了值,操作表时的sql会是schema.tablename
     * 
如果同时设置了catalog,优先使用catalog.tablename * * @param schema */ public void setSchema(String schema) { this.schema = schema; } /** * 获取序列格式化模板 * * @return */ public String getSeqFormat() { if (StringUtil.isNotEmpty(this.seqFormat)) { return this.seqFormat; } return "{0}.nextval"; } /** * 序列的获取规则,使用{num}格式化参数,默认值为{0}.nextval,针对Oracle *
可选参数一共3个,对应0,1,2,3分别为SequenceName,ColumnName, PropertyName,TableName * * @param seqFormat */ public void setSeqFormat(String seqFormat) { this.seqFormat = seqFormat; } public Style getStyle() { return this.style == null ? Style.camelhump : this.style; } public void setStyle(Style style) { this.style = style; } public String getWrapKeyword() { return wrapKeyword; } public void setWrapKeyword(String wrapKeyword) { this.wrapKeyword = wrapKeyword; } /** * 获取SelectKey的Order * * @return */ public boolean isBEFORE() { return BEFORE; } public void setBEFORE(boolean BEFORE) { this.BEFORE = BEFORE; } public boolean isCheckExampleEntityClass() { return checkExampleEntityClass; } public void setCheckExampleEntityClass(boolean checkExampleEntityClass) { this.checkExampleEntityClass = checkExampleEntityClass; } public boolean isEnableMethodAnnotation() { return enableMethodAnnotation; } public void setEnableMethodAnnotation(boolean enableMethodAnnotation) { this.enableMethodAnnotation = enableMethodAnnotation; } public boolean isEnumAsSimpleType() { return enumAsSimpleType; } public void setEnumAsSimpleType(boolean enumAsSimpleType) { this.enumAsSimpleType = enumAsSimpleType; } public boolean isNotEmpty() { return notEmpty; } public void setNotEmpty(boolean notEmpty) { this.notEmpty = notEmpty; } public boolean isUseSimpleType() { return useSimpleType; } public void setUseSimpleType(boolean useSimpleType) { this.useSimpleType = useSimpleType; } /** * 主键自增回写方法执行顺序,默认AFTER,可选值为(BEFORE|AFTER) * * @param order */ public void setOrder(String order) { this.BEFORE = "BEFORE".equalsIgnoreCase(order); } public String getIdentity() { return getIDENTITY(); } public void setIdentity(String identity) { setIDENTITY(identity); } public List getMappers() { return mappers; } public void setMappers(List mappers) { this.mappers = mappers; } public boolean isBefore() { return isBEFORE(); } public void setBefore(boolean before) { setBEFORE(before); } public Class getResolveClass() { return resolveClass; } public void setResolveClass(Class resolveClass) { this.resolveClass = resolveClass; } public boolean isSafeDelete() { return safeDelete; } public void setSafeDelete(boolean safeDelete) { this.safeDelete = safeDelete; } public boolean isSafeUpdate() { return safeUpdate; } public void setSafeUpdate(boolean safeUpdate) { this.safeUpdate = safeUpdate; } public boolean isUseJavaType() { return useJavaType; } public void setUseJavaType(boolean useJavaType) { this.useJavaType = useJavaType; } public boolean isEnableBaseResultMapFlag() { return enableBaseResultMapFlag; } public void setEnableBaseResultMapFlag(boolean enableBaseResultMapFlag) { this.enableBaseResultMapFlag = enableBaseResultMapFlag; } /** * 配置属性 * * @param properties */ public void setProperties(Properties properties) { if (properties == null) { //默认驼峰 this.style = Style.camelhump; return; } String IDENTITY = properties.getProperty("IDENTITY"); if (StringUtil.isNotEmpty(IDENTITY)) { setIDENTITY(IDENTITY); } String seqFormat = properties.getProperty("seqFormat"); if (StringUtil.isNotEmpty(seqFormat)) { setSeqFormat(seqFormat); } String catalog = properties.getProperty("catalog"); if (StringUtil.isNotEmpty(catalog)) { setCatalog(catalog); } String schema = properties.getProperty("schema"); if (StringUtil.isNotEmpty(schema)) { setSchema(schema); } //ORDER 有三个属性名可以进行配置 String ORDER = properties.getProperty("ORDER"); if (StringUtil.isNotEmpty(ORDER)) { setOrder(ORDER); } ORDER = properties.getProperty("order"); if (StringUtil.isNotEmpty(ORDER)) { setOrder(ORDER); } ORDER = properties.getProperty("before"); if (StringUtil.isNotEmpty(ORDER)) { setBefore(Boolean.valueOf(ORDER)); } this.notEmpty = Boolean.valueOf(properties.getProperty("notEmpty")); this.enableMethodAnnotation = Boolean.valueOf(properties.getProperty("enableMethodAnnotation")); this.checkExampleEntityClass = Boolean.valueOf(properties.getProperty("checkExampleEntityClass")); //默认值 true,所以要特殊判断 String useSimpleTypeStr = properties.getProperty("useSimpleType"); if (StringUtil.isNotEmpty(useSimpleTypeStr)) { this.useSimpleType = Boolean.valueOf(useSimpleTypeStr); } this.enumAsSimpleType = Boolean.valueOf(properties.getProperty("enumAsSimpleType")); //注册新的基本类型,以逗号隔开,使用全限定类名 String simpleTypes = properties.getProperty("simpleTypes"); if (StringUtil.isNotEmpty(simpleTypes)) { SimpleTypeUtil.registerSimpleType(simpleTypes); } //使用 8 种基本类型 if (Boolean.valueOf(properties.getProperty("usePrimitiveType"))) { SimpleTypeUtil.registerPrimitiveTypes(); } String styleStr = properties.getProperty("style"); if (StringUtil.isNotEmpty(styleStr)) { try { this.style = Style.valueOf(styleStr); } catch (IllegalArgumentException e) { throw new MapperException(styleStr + "不是合法的Style值!"); } } else { //默认驼峰 this.style = Style.camelhump; } //处理关键字 String wrapKeyword = properties.getProperty("wrapKeyword"); if (StringUtil.isNotEmpty(wrapKeyword)) { this.wrapKeyword = wrapKeyword; } //安全删除 this.safeDelete = Boolean.valueOf(properties.getProperty("safeDelete")); //安全更新 this.safeUpdate = Boolean.valueOf(properties.getProperty("safeUpdate")); //是否设置 javaType,true 时如 {id, javaType=java.lang.Long} this.useJavaType = Boolean.valueOf(properties.getProperty("useJavaType")); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy