【Java教程】mybatisPlus yml如何配置方式详解

所需工具:

Java

聪明的大脑

勤劳的双手

 

注意:本站只提供教程,不提供任何成品+工具+软件链接,仅限用于学习和研究,禁止商业用途,未经允许禁止转载/分享等

 

教程如下

mybatisPlus yml配置

 	
 	spring:
 	     datasource:
 	     driver-class-name: com.mysql.cj.jdbc.Driver
 	     username: root
 	     password: 11111111
 	     url: jdbc:mysql://localhost:3306/myInfo useUnicode=true& characterEncoding=UTF-8& zeroDateTimeBehavior=convertToNull
 	     # 初始化时建立的物理连接数。初始化发生在显式调用init方法,或者第一次getConnection时.
 	     initial-size: 5
 	     # 连接池最大物理连接数量。
 	     max-active: 50
 	     # 连接池最小物理连接数量。
 	     min-idle: 5
 	     # 获取连接时最大等待时间,单位为毫秒。
 	     # 配置之后,缺省启用公平锁,并发效率会有所下降,若需要可以通过配置useUnfairLock属性为true使用非公平锁。
 	     max-wait: 6000
 	     # 是否缓存preparedStatement,也就是PSCache。
 	     # PSCache对支持游标的 数据库性能提升巨大,比如说oracle。在mysql下建议关闭。
 	     pool-prepared-statements: true
 	     # 要启用PSCache,其值必须大于0,当大于0时,poolPreparedStatements自动触发修改为true。
 	     # 在Druid中,不会存在Oracle下PSCache占用内存过多的问题,可以把这个数值配置大一些,比如说100。
 	     max-pool-prepared-statement-per-connection-size: 20
 	     # 用来检测连接是否有效的sql,要求是一个查询语句,常用select 'x'。
 	     # 如果validationQuery为null,testOnBorrow、testOnReturn、testWhileIdle都不会起作用。
 	     validation-query: select 1 from dual
 	     # 检测连接是否有效的超时时间,单位为秒。
 	     # 底层调用jdbc Statement对象的void setQueryTimeout(int seconds)方法。
 	     # validation-query-timeout: 30
 	     # 有两个含义:
 	     # 1) Destroy线程会检测连接的间隔时间,若连接空闲时间大于等于minEvictableIdleTimeMillis则关闭物理连接。
 	     # 2) testWhileIdle的判断依据,详细看testWhileIdle属性的说明。
 	     time-between-eviction-runs-millis: 60000
 	     # 连接保持空闲而不被驱逐的最长时间。
 	     min-evictable-idle-time-millis: 300000
 	     # 建议配置为true,不影响性能,并且保证安全性。
 	     # 申请连接的时候检测,若空闲时间大于timeBetweenEvictionRunsMillis,执行validationQuery检测连接是否有效。
 	     test-while-idle: true
 	     # 申请连接时执行validationQuery检测连接是否有效,做了这个配置会降低性能。
 	     test-on-borrow: false
 	     # 归还连接时执行validationQuery检测连接是否有效,做了这个配置会降低性能。
 	     test-on-return: false
 	     # 类型是字符串,通过别名的方式配置扩展的拦截器插件,常用的拦截器插件有:
 	     # 监控统计用的filter:stat,日志用的filter:log4j,防御sql注入攻击的filter:wall,三个同时配置的化,用逗号隔开。
 	     # 注意,Druid中的filter-class-names配置项是不起作用的,必须采用filters配置项才可以。
 	     filters: stat,wall,log4j2
 	     # 通过connectProperties属性来打开mergeSql功能;慢SQL记录。
 	     connect-properties: druid.stat.mergeSql=true;druid.stat.slowSqlMillis=5000
 	     # 合并多个DruidDataSource的监控数据
 	     use-global-data-source-stat: true
 	
 	mybatis-plus:
 	     mapper-locations: classpath*:/dao/**/*Dao.xml
 	     # 数据库支持id唯一
 	     global-config:
 	     id-type: ASSIGN_ID
 	     capital-mode: false

mybatisPlus3.X yml配置

 	mybatis-plus:
 	     # Mapper.xml 文件位置 Maven 多模块项目的扫描路径需以 classpath*: 开头
 	     mapperLocations: classpath*:com/vanhr/**/xml/*Mapper.xml
 	# #MyBaits 别名包扫描路径,通过该属性可以给包中的类注册别名 实体扫描,多个package用逗号或者分号分隔
 	# typeAliasesPackage: com.vanhr.user.dao.entity
 	# #通过父类(或实现接口)的方式来限定扫描实体
 	# typeAliasesSuperType: com.vanhr.user.dao.entity.baseEntity
 	# #枚举类 扫描路径 如果配置了该属性,会将路径下的枚举类进行注入,让实体类字段能够简单快捷的使用枚举属性
 	# typeEnumsPackage: com.vanhr.user.dao.enums
 	# #启动时是否检查 MyBatis XML 文件的存在,默认不检查 仅限spring boot 使用
 	# checkConfigLocation : true
 	# #通过该属性可指定 MyBatis 的执行器,MyBatis 的执行器总共有三种:
 	# # ExecutorType.SIMPLE:该执行器类型不做特殊的事情,为每个语句的执行创建一个新的预处理语句(PreparedStatement)
 	# # ExecutorType.REUSE:该执行器类型会复用预处理语句(PreparedStatement)
 	# # ExecutorType.BATCH:该执行器类型会批量执行所有的更新语句
 	# executorType: SIMPLE
 	# # 指定外部化 MyBatis Properties 配置,通过该配置可以抽离配置,实现不同环境的配置部署
 	# configurationProperties:
 	     configuration: # MyBatis 原生支持的配置
 	     # 是否开启自动驼峰命名规则(camel case)映射
 	     mapUnderscoreToCamelCase: true
 	     # 枚举处理类,如果配置了该属性,枚举将统一使用指定处理器进行处理
 	     # org.apache.ibatis.type.EnumTypeHandler : 存储枚举的名称
 	     # org.apache.ibatis.type.EnumOrdinalTypeHandler : 存储枚举的索引
 	     # com.baomidou.mybatisplus.extension.handlers.MybatisEnumTypeHandler : 枚举类需要实现IEnum接口或字段标记@EnumValue注解.(3.1.2以下版本为EnumTypeHandler)
 	# defaultEnumTypeHandler: com.baomidou.mybatisplus.extension.handlers.MybatisEnumTypeHandler
 	     # 配置JdbcTypeForNull, oracle数据库必须配置
 	     jdbc-type-for-null: null
 	     global-config: # 全局策略配置
 	     # 是否控制台 print mybatis-plus 的 LOGO
 	     banner: false
 	     db-config:
 	         # id类型
 	         id-type: auto
 	         # 表名是否使用下划线命名,默认数据库表使用下划线命名
 	         table-underline: true
 	         #是否开启大写命名,默认不开启
 	# capital-mode: false
 	# #逻辑已删除值,(逻辑删除下有效) 需要注入逻辑策略LogicSqlInjector 以@Bean方式注入
 	# logic-not-delete-value: 0
 	# #逻辑未删除值,(逻辑删除下有效)
 	# logic-delete-value: 1

 

 

标签

发表评论