zoukankan      html  css  js  c++  java
  • MybatisPlus的FieldStrategy

    起源

    今天在新项目中打算使用Mybatis Plus3.x版本,然后发现2.x版本中有些配置被废弃了。其中一个field-strategy引起了注意。
    一时偷懒可能会导致线上问题,所以还是研究一下。

    正文

    MP中,该设置会影响sql语句的拼接行为。在2.x版本中,没有对这个进行区分,不可单独设置字段策略。
    下面通过具体的配置来解释差异

    # 2.x配置
    mybatis-plus:
      mapper-locations:
        - classpath*:mapper/**/*Mapper.xml
      typeAliasesPackage: com.test.assist.dao.domain
      global-config:
        id-type: 0
        field-strategy: 2
        db-column-underline: true
      configuration:
        map-underscore-to-camel-case: true
        cache-enabled: false
    #3.x的配置
    mybatis-plus:
      typeAliasesPackage: com.test.assist.dao.domain
      mapper-locations:
        - classpath*:mapper/**/*Mapper.xml
      global-config:
        db-config:
          select-strategy: not_empty
          insert-strategy: not_empty
          update-strategy: not_empty
          id-type: auto
      configuration:
        map-underscore-to-camel-case: true
        cache-enabled: false
    public enum FieldStrategy {
        IGNORED,
        NOT_NULL,
        NOT_EMPTY,
        DEFAULT,
        NEVER;
    
        private FieldStrategy() {
        }
    }

    通过查阅资料和翻看源码,发现这个字段主要会影响sql拼接。我们知道,当通过Entity对表进行更新时,只会更新非空字段。对于那些值为NULL的字段是不会出现在sql语句里的。
    下面我从源码里面截取了一段

    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>";
            } else {
                String property = fieldInfo.getProperty();
                Class propertyType = fieldInfo.getPropertyType();
                property = StringUtils.removeIsPrefixIfBoolean(property, propertyType);
                if (null != prefix) {
                    property = prefix + property;
                }
                //重点是这里,如果字段策略为NOT_EMPTY,那么会对当前字段的值进行判断
                if (fieldStrategy == FieldStrategy.NOT_EMPTY) {
                    return StringUtils.isCharSequence(propertyType) ? String.format("
    	<if test="%s!=null and %s!=''">", property, property) : String.format("
    	<if test="%s!=null ">", property);
                } else {
                    return String.format("
    	<if test="%s!=null">", property);
                }
            }
        }

    通过上面的代码可以总结出:

    • NOT_EMPTY:会对字段值进行null和'' 比较操作
    • NOT_NULL: 只会进行null检查

    同时在3.x版本中,支持对selectupdateinsert设置不同的字段策略,由此看来大家对这种一刀切的行为还是比较反感的。这一点,我在github也看到issue

    总结

    对于不清楚的配置不能囫囵吞枣,否则容易酿成大祸。

    参考文献





    网络知识搬运/梳理小工
  • 相关阅读:
    20155318 《网络攻防》Exp6 信息搜集与漏洞扫描
    20155318 《网络攻防》Exp5 MSF基础应用
    20155318 《网络攻防》Exp4 恶意代码分析
    20155318 《网络攻防》Exp3 免杀原理与实践
    20155318 《网络攻防》Exp2 后门原理与实践
    20155318 Exp1 PC平台逆向破解(5)M
    20155318 第十六周课堂实践——嵌入式基础
    2017-2018-2 20155309 南皓芯 Exp9 Web安全基础
    2017-2018-2 20155309南皓芯 Exp8 WEB基础实践
    2017-2018-2 20155309 南皓芯 Exp7 网络欺诈防范
  • 原文地址:https://www.cnblogs.com/aibilim/p/f83eda1a60d17b176f30343fa4c11b6d.html
Copyright © 2011-2022 走看看