其他分享
首页 > 其他分享> > Mybatis --- 全局配置文件

Mybatis --- 全局配置文件

作者:互联网

Mybatis — 全局配置文件

上一篇介绍了Mybatis的入门体验Mybatis — 入门初体验
这一篇就来介绍下Mybatis中的具体有哪些配置文件
  1. properties 属性

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

  1. settings 设置 :

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

  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中查询了在这里插入图片描述
  1. mapper映射
    映射文件指导着MyBatis如何进行数据库增删改查在这里插入图片描述
    >> 映射文件中的几个配置(EmployeeMapper.xml) :
    • cache –命名空间的二级缓存配置
    • cache-ref – 其他命名空间缓存配置的引用。
    • resultMap – 自定义结果集映射
    • parameterMap – 已废弃!老式风格的参数映射
    • sql –抽取可重用语句块。
    • insert – 映射插入语句
    • update – 映射更新语句
    • delete – 映射删除语句
    • select – 映射查询语句
    >> insert、update、delete元素中的几个属性, 黄色区域比较经常用到 :
    在这里插入图片描述

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

标签:语句,databaseId,配置文件,映射,配置,MyBatis,Mybatis,全局
来源: https://blog.csdn.net/weixin_43287239/article/details/100778878