Mybatis框架-----配置文件
文章目录
- 🔥一、全局配置
-
- 🌙1.1、配置事项
- 🌙1.2、配置标签
-
- 🌟1.2.1、标签作用以及图示
- 🌟1.2.2、setting标签的参数设置
- 🌟1.2.3、常见的 Java 类型内建的类型别名
- 🌟1.2.4、environments标签中的节点和标签
- 🔥 二、映射配置文件
-
- 🌙2.1、映射配置文件图
- 🌙2.2、映射文件中的标签元素
✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨
🔥一、全局配置
🌙1.1、配置事项
全局配置文件的名称是自定义的,在项目中放在src目录下.
全局配置文件的作用:完成一些全局性的配置
例如:对mybatis框架的设置,别名的配置,环境的配置,绑定映射配置文件等相关配置
✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨
🌙1.2、配置标签
mybatis的全局配置文件中的根标签是
configure
还有properties
标签、setting
标签、typeAliases
标签、environments
标签、mapper
标签等等
🌟1.2.1、标签作用以及图示
序号 | 标签 | 作用 | 图示 |
---|---|---|---|
🌞1 | configure | 头标签(用来放其他标签) | |
🌞2 | properties | Mybatis配置文件中的属性定义,。properties 标签中允许内部定义属性,也可以是外部的,properties文件定义属性。无论是内部定义还是外部定义,都可以使用${name}获取值。 | |
🌞3 | setting | 配置 MyBatis 框架运行时的一些行为的,例如缓存、延迟加载、结果集控制、执行器、分页设置、命名规则等一系列控制性参数,其所有的 setting 配置都放在父标签 settings 标签中。 | |
🌞4 | typeAliases | 类型别名可为 Java 类型设置一个缩写名字 | |
🌞5 | environments | MyBatis可以配置多个环境 | |
🌞6 | mapper | 指定映射配置文件 |
✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨
🌟1.2.2、setting标签的参数设置
setting标签中设置的参数 | 描述 | 有效值 | 默认值 |
---|---|---|---|
cacheEnabled | 该配置影响的所有映射器中配置的缓存的全局开关 | true/false | true |
lazyLoadingEnabled | 延迟加载的全局开关。当开启时,所有关联对象都会延迟加载。特定关联关系中可通过设置fetchType属性来覆盖该项的开关状态。 | true/false | false |
multipleResultSetsEnabled | 是否允许单一语句返回多结果集(需要兼容驱动)。 | true/false | true |
useColumnLabel | 使用列标签代替列名。不同的驱动在这方面会有不同的表现,具体可参考相关驱动文档或通过测试这两种不同的模式来观察所用驱动的结果。 | true/false | true |
useGeneratedKeys | 允许 JDBC 支持自动生成主键,需要驱动兼容。如果设置为true 则这个设置强制使用自动生成主键,尽管一些驱动不能兼容但仍可正常工作(比如 Derby)。 | true/false | false |
autoMappingBehavior | 指定 MyBatis 是否以及如何自动映射指定的列到字段或属性。NONE 表示取消自动映射;PARTIAL 只会自动映射没有定义嵌套结果集映射的结果集。FULL 会自动映射任意复杂的结果集(包括嵌套和其他情况)。 | true/false | true |
defaultExecutorType | 配置默认的执行器。SIMPLE 就是普通的执行器;REUSE 执行器会重用预处理语句(preparedstatements);BATCH 执行器将重用语句并执行批量更新。 | SIMPLE、 REUSE、 BATCH | SIMPLE |
defaultStatementTimeout | 设置超时时间,它决定驱动等待数据库响应的秒数 | any / positive / integer | false |
defaultStatementTimeout | 设置超时时间,它决定驱动等待数据库响应的秒数 | any / positive / integer | false |
mapUnderscoreToCamelCase | 是否开启自动驼峰命名规则(camelcase)映射,即从经典数据库列名 A_COLUMN 到经典 Java 属性名 aColumn 的类似映射。 | true/false | false |
localCacheScope | MyBatis 利用本地缓存机制(Local Cache)防止循环引用(circularreferences)和加速重复嵌套查询。默认值为 SESSION,这种情况下会缓存一个会话中执行的所有查询。若设置值为STATEMENT,本地会话仅用在语句执行上,对相同 SqlSession 的不同调用将不会共享数据 | SESSION/STATEMENT | SESSION |
jdbcTypeForNull | 当没有为参数提供特定的 JDBC 类型时,为空值指定 JDBC 类型。某些驱动需要指定列的 JDBC 类型,多数情况直接用一般类型即可,比如 NULL、VARCHAR 或 OTHER。 | JdbcType 常量,常用值:NULL、VARCHAR 或OTHER。 | OTHER |
lazyLoadTriggerMethods | 指定哪个对象的方法触发一次延迟加载。 | 用逗号分隔的方法列表 | equals,clone,hashCode,toString |
defaultScriptingLanguage | 指定动态 SQL 生成使用的默认脚本语言。 | 一个类型别名或全限定类名 | org.apache.ibatis.scripting.xmltags.XMLLanguageDriver |
callSettersOnNulls | 指定当结果集中值为 null 的时候是否调用映射对象的 setter(map 对象时为 put)方法,这对于有 Map.keySet() 依赖或 null值初始化的时候是有用的。注意原始类型(int、boolean 等)是不能设置成 null 的。 | true/false | false |
logPrefix | 指定 MyBatis 增加到日志名称的前缀 | 任何字符串 | 未设置 |
logImpl | 指定 MyBatis 所用日志的具体实现,未指定时将自动查找。 | SLF4J /LOG4J/LOG4J2/JDK_LOGGING/COMMONS_LOGGING/STDOUT_LOGGING /NO_LOGGING | 未设置 |
proxyFactory | 为 Mybatis 用来创建具有延迟加载能力的对象设置代理工具 | CGLIB/JAVASSIST | JAVASSIST(MyBatis 3.3 以上) |
✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨
🌟1.2.3、常见的 Java 类型内建的类型别名
✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨
🌟1.2.4、environments标签中的节点和标签
✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨
🔥 二、映射配置文件
映射配置文件主要是用来编写
sql
语句的,结果集的映射关系的指定,以及缓存的一些
配置等等。
🌙2.1、映射配置文件图
✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨
🌙2.2、映射文件中的标签元素
序号 | 标签元素 | 作用 | 包含元素 |
---|---|---|---|
🌞1 | resultMap | 指定查询结果集与对象的映射关系,是最复杂也是最强大的标签。 | id、type、result、 association、collection |
🌞2 | id | 指定主键中的值,用于标识一个结果映射。 | 无 |
🌞3 | type | 类的完全名, 或者一个类型别名 | 无 |
🌞4 | result | 指定非主键中的值,用于标识一个结果映射 | 无 |
🌞5 | association | 通常用来映射一对一的关系。 | 无 |
🌞6 | collection | 通常用来映射一对多的关系。 | 无 |
🌞7 | select | 查询语句。 | id、parameterType、resultType、resultMap |
🌞8 | parameterType | 指定参数类型.该属性是可选属性(因为mybatis可以通过类型处理器(TypeHandler)推断出具体传入语句的参数) | 无 |
🌞9 | resultType | 期望这条SQL语句返回结果的类全名或别名。 | 无 |
🌞10 | resultMap | 使用resultMap标签来处理结果集映射。 | 无 |
🌞11 | insert | 添加语句。 | id、parameterType |
🌞12 | update | 更新语句。 | id、parameterType、 |
🌞13 | delete | 删除语句。 | id、parameterType |
🌞14 | sql | 定义可以重复使用的SQL 语句。 |
id |
🌞15 | include | 引入sql标签定义的片段。 | id |
✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨