java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > MyBatis-Plus YAML配置

MyBatis-Plus YAML配置全过程

作者:Full Stack Developme

这段配置示例详细介绍了MyBatis-Plus的核心配置项,包括基础配置、分页插件配置、多环境配置等,帮助开发者快速搭建高效的数据访问层,重点配置项如全局主键类型、逻辑删除字段、分页插件配置等,确保配置灵活且高效

一、基础配置示例

# application.yml
mybatis-plus:
  # 全局配置
  global-config:
    # 是否打印banner
    banner: true
    # 数据库相关配置
    db-config:
      # 主键类型 (AUTO:数据库自增, INPUT:手动输入, ASSIGN_ID:雪花算法, ASSIGN_UUID:UUID)
      id-type: auto
      # 表名是否使用下划线命名 (默认:true)
      table-underline: true
      # 逻辑删除字段名
      logic-delete-field: deleted
      # 逻辑删除值(默认:1)
      logic-delete-value: 1
      # 逻辑未删除值(默认:0)
      logic-not-delete-value: 0
      # 插入时是否自动填充字段
      insert-strategy: not_null
      # 更新时是否自动填充字段
      update-strategy: not_null
      # 查询时是否自动填充字段
      where-strategy: not_null
      # 数据库类型
      db-type: mysql
    # 刷新mapper
    refresh-mapper: true
  # 配置mapper.xml文件位置
  mapper-locations: 
    - classpath*:/mapper/**/*.xml
    - classpath*:/mybatis/mapper/*.xml
  # 实体类包路径(用于别名)
  type-aliases-package: com.example.demo.entity
  # TypeHandler包路径
  type-handlers-package: com.example.demo.handler
  # 配置MyBatis基础配置
  configuration:
    # 开启驼峰命名转换
    map-underscore-to-camel-case: true
    # 开启二级缓存
    cache-enabled: true
    # 开启延迟加载
    lazy-loading-enabled: true
    # 积极懒加载(false表示按需加载)
    aggressive-lazy-loading: false
    # 开启sql日志
    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
    # 默认执行器(REUSE:重用预处理语句)
    default-executor-type: reuse
    # 是否开启自动映射
    auto-mapping-behavior: partial
    # 是否允许JDBC生成主键
    use-generated-keys: true
  # 配置类型处理器包
  type-enums-package: com.example.demo.enums

二、分页插件配置

mybatis-plus:
  # 分页插件配置
  configuration:
    # 分页方言
    call-setters-on-nulls: true
  # 全局分页配置
  global-config:
    db-config:
      # 分页大小
      pagination-interceptor:
        # 默认每页条数
        default-page-size: 10
        # 最大每页条数
        max-limit: 1000

三、多环境配置示例

# application-dev.yml (开发环境)
mybatis-plus:
  configuration:
    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
  global-config:
    banner: true
    db-config:
      logic-delete-value: 1
      logic-not-delete-value: 0
# application-prod.yml (生产环境)
mybatis-plus:
  configuration:
    log-impl: org.apache.ibatis.logging.nologging.NoLoggingImpl
  global-config:
    banner: false
    db-config:
      logic-delete-value: 1
      logic-not-delete-value: 0

四、完整配置参数说明表

配置项说明默认值可选值
global-config.banner是否打印bannertruetrue/false
global-config.refresh-mapper是否刷新mapperfalsetrue/false
global-config.db-config.id-type全局主键类型ASSIGN_IDAUTO, INPUT, ASSIGN_ID, ASSIGN_UUID, NONE
global-config.db-config.table-underline表名、字段名下划线转驼峰truetrue/false
global-config.db-config.logic-delete-field逻辑删除字段名deleted自定义字段名
global-config.db-config.logic-delete-value逻辑删除值1任意值
global-config.db-config.logic-not-delete-value逻辑未删除值0任意值
global-config.db-config.db-type数据库类型UNKNOWNMYSQL, ORACLE, SQLSERVER, POSTGRE_SQL等
mapper-locationsMapper XML文件位置classpath:/mapper/**/.xml自定义路径
type-aliases-package实体类包路径null包路径
type-handlers-packageTypeHandler包路径null包路径
configuration.map-underscore-to-camel-case驼峰命名转换truetrue/false
configuration.cache-enabled二级缓存开关truetrue/false
configuration.lazy-loading-enabled延迟加载开关falsetrue/false
configuration.log-impl日志实现StdOutImpl, Slf4jImpl等
configuration.default-executor-type默认执行器类型SIMPLESIMPLE, REUSE, BATCH
configuration.auto-mapping-behavior自动映射行为PARTIALNONE, PARTIAL, FULL

五、常用组合配置示例

1. MySQL开发环境配置

mybatis-plus:
  mapper-locations: classpath*:/mapper/**/*.xml
  type-aliases-package: com.example.entity
  global-config:
    db-config:
      id-type: auto
      logic-delete-field: deleted
      logic-delete-value: 1
      logic-not-delete-value: 0
  configuration:
    map-underscore-to-camel-case: true
    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
    cache-enabled: false

2. Oracle生产环境配置

mybatis-plus:
  mapper-locations: classpath*:/mapper/oracle/**/*.xml
  type-aliases-package: com.example.entity
  global-config:
    db-config:
      id-type: input
      db-type: oracle
      logic-delete-field: is_deleted
      logic-delete-value: Y
      logic-not-delete-value: N
  configuration:
    map-underscore-to-camel-case: true
    log-impl: org.apache.ibatis.logging.nologging.NoLoggingImpl
    cache-enabled: true

六、注意事项

  1. 配置优先级:XML配置 > YAML配置 > 默认配置

  2. 逻辑删除:需要在实体类对应字段添加 @TableLogic 注解

  3. 分页插件:需要单独配置 PaginationInterceptor Bean

  4. 性能优化:生产环境关闭SQL日志输出

  5. 版本兼容:不同版本配置项可能有差异,建议查阅对应版本文档

这个配置涵盖了MyBatis-Plus的大部分常用配置,可以根据实际项目需求进行调整。

七、总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
阅读全文