Mybatis --- 全局配置文件

Mybatis — 全局配置文件

上一篇介绍了Mybatis的入门体验Mybatis — 入门初体验
这一篇就来介绍下Mybatis中的具体有哪些配置文件
  • MyBatis 的配置文件包含了影响 MyBatis 行为甚深的设置(settings)和属性(properties)信息。文档的顶层结构如下:
    configuration 配置
    	• properties 属性
    	• settings 设置
    	• typeAliases 类型命名
    	• typeHandlers 类型处理器
    	• objectFactory 对象工厂
    	• plugins 插件
    	• environments 环境
    	• environment 环境变量
    	• transactionManager 事务管理器
    	• dataSource 数据源
    	• databaseIdProvider 数据库厂商标识
    	• mappers 映射器
    
  • 项目工程的路径目录
    在这里插入图片描述
  1. properties 属性

我们在项目的类路径下新建一个dbconfig.properties:
在这里插入图片描述
然后在mybatis-config.xml中添加配置:
在这里插入图片描述
这样子我们就可以在配置数据源的时候使用properties文件中的参数了(用${xxx}获取值):
在这里插入图片描述

  1. settings 设置 :

这是 MyBatis 中极为重要的调整设置,它们会改变MyBatis 的运行时行为. 找来了一张图, 黄色区域为常用设置:
在这里插入图片描述

  • mapUnderscoreToCamelCase设置: 开启驼峰映射(在数据表中如果字段是last_name就可以映射实体中的lastName):
    在这里插入图片描述
  • typeAliases别名处理器 :
    在这里插入图片描述
    这里我们也可以使用@Alias注解直接为实体起别名 :
    在这里插入图片描述
    注意点:MyBatis已经为许多常见的 Java 类型内建了相应的类型别名。它们都是大小写不敏感的,我们在起别名的时候千万不要占用已有的别名。
    在这里插入图片描述
  1. typeHandlers 类型处理器
    无论是 MyBatis 在预处理语句(PreparedStatement)中设置一个参数时,还是从结果集中取出一个值时, 都会用类型处理器将获取的值以合适的方式转换成 Java 类型。
    在这里插入图片描述
    除了使用已有的类型处理器, 我们还可以自定义类型处理器 :
    1)、实现org.apache.ibatis.type.TypeHandler接口或者继承org.apache.ibatis.type.BaseTypeHandler
    2)、指定其映射某个JDBC类型(可选操作)
    3)、在mybatis全局配置文件中注册
  2. plugins插件
    我们可以通过插件来修改MyBatis的一些核心行为。插件通过动态代理机制,可以介入四大对象的任何一个方法的执行
    • Executor (update, query, flushStatements, commit, rollback,getTransaction, close, isClosed)
    • ParameterHandler (getParameterObject, setParameters)
    • ResultSetHandler (handleResultSets, handleOutputParameters)
    • StatementHandler (prepare, parameterize, batch, update, query)
  3. environments / environment / transactionManager / dataSource 配置
    • MyBatis可以配置多种环境,比如开发、测试和生产环境需要有不同的配置。
    • 每种环境使用一个environment标签进行配置并指定唯一标识符
    • 可以通过environments标签中的default属性指定一个环境的标识符来快速的切换环境
    这里配置了Mysql和Oracle两个环境
    <!-- 
    	4、environments:环境,mybatis可以配置多种环境 ,default指定使用某种环境。可以达到快速切换环境。
    		environment:配置一个具体的环境信息;必须有两个标签;id代表当前环境的唯一标识
     transactionManager:事务管理器;
    					type:事务管理器的类型;JDBC(JdbcTransactionFactory)|MANAGED(ManagedTransactionFactory)
    					自定义事务管理器:实现TransactionFactory接口.type指定为全类名
            dataSource:数据源
    					type:数据源类型 : UNPOOLED(UnpooledDataSourceFactory)
    							         POOLED(PooledDataSourceFactory)
    							         JNDI(JndiDataSourceFactory)
    					自定义数据源:实现DataSourceFactory接口,type是全类名
    	 -->
    <environments default="mysql">
    	<environment id="mysql">
    		<transactionManager type="JDBC"></transactionManager>
    		<dataSource type="POOLED">
    			<property name="driver" value="${jdbc.driver}" />
    			<property name="url" value="${jdbc.url}" />
    			<property name="username" value="${jdbc.username}" />
    			<property name="password" value="${jdbc.password}" />
    		</dataSource>
    	</environment>
    	<environment id="oracle">
    		<transactionManager type="JDBC" />
    		<dataSource type="POOLED">
    			<property name="driver" value="${orcl.driver}" />
    			<property name="url" value="${orcl.url}" />
    			<property name="username" value="${orcl.username}" />
    			<property name="password" value="${orcl.password}" />
    		</dataSource>
    	</environment>
    </environments>
    
  4. databaseIdProvider 数据库厂商标识
    MyBatis 可以根据不同的数据库厂商执行不同的语句。
    <!-- 5、databaseIdProvider:支持多数据库厂商的;
    	 type="DB_VENDOR":VendorDatabaseIdProvider
    	 	作用就是得到数据库厂商的标识(驱动getDatabaseProductName()),mybatis就能根据数据库厂商标识来执行不同的sql;
    	 	MySQL,Oracle,SQL Server,xxxx
      -->
    <databaseIdProvider type="DB_VENDOR">
    	<!-- 为不同的数据库厂商起别名 -->
    	<property name="MySQL" value="mysql"/>
    	<property name="Oracle" value="oracle"/>
    	<property name="SQL Server" value="sqlserver"/>
    </databaseIdProvider>
    
    上面在xml中配置完后我们就可以在sql映射文件指定了 :
    这样查询数据表就会从oracle中查询了在这里插入图片描述
  • MyBatis匹配规则如下:
    1、如果没有配置databaseIdProvider标签,那么databaseId=null
    2、如果配置了databaseIdProvider标签,使用标签配置的name去匹配数据库信息,匹配上设置databaseId=配置指定的值,否则依旧为null
    3、如果databaseId不为null,他只会找到配置databaseId的sql语句
    4、MyBatis 会加载不带 databaseId 属性和带有匹配当前数据库databaseId 属性的所有语句。如果同时找到带有 databaseId 和不带databaseId 的相同语句,则后者会被舍弃。
  1. mapper映射
    映射文件指导着MyBatis如何进行数据库增删改查在这里插入图片描述
    >> 映射文件中的几个配置(EmployeeMapper.xml) :
    • cache –命名空间的二级缓存配置
    • cache-ref – 其他命名空间缓存配置的引用。
    • resultMap – 自定义结果集映射
    • parameterMap – 已废弃!老式风格的参数映射
    • sql –抽取可重用语句块。
    • insert – 映射插入语句
    • update – 映射更新语句
    • delete – 映射删除语句
    • select – 映射查询语句
    >> insert、update、delete元素中的几个属性, 黄色区域比较经常用到 :
    在这里插入图片描述

以上就是Mybatis中全局配置文件中的内容了, 欢迎参考交流…(需要源码的评论区留言占位)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值