Mybatis --- 全局配置文件
作者:互联网
Mybatis — 全局配置文件
上一篇介绍了Mybatis的入门体验Mybatis — 入门初体验
这一篇就来介绍下Mybatis中的具体有哪些配置文件
-
MyBatis 的配置文件包含了影响 MyBatis 行为甚深的设置(settings)和属性(properties)信息。文档的顶层结构如下:
configuration 配置
• properties 属性 • settings 设置 • typeAliases 类型命名 • typeHandlers 类型处理器 • objectFactory 对象工厂 • plugins 插件 • environments 环境 • environment 环境变量 • transactionManager 事务管理器 • dataSource 数据源 • databaseIdProvider 数据库厂商标识 • mappers 映射器
-
项目工程的路径目录
我们在项目的类路径下新建一个dbconfig.properties:
然后在mybatis-config.xml中添加配置:
这样子我们就可以在配置数据源的时候使用properties文件中的参数了(用${xxx}获取值):
这是 MyBatis 中极为重要的调整设置,它们会改变MyBatis 的运行时行为. 找来了一张图, 黄色区域为常用设置:
- mapUnderscoreToCamelCase设置: 开启驼峰映射(在数据表中如果字段是last_name就可以映射实体中的lastName):
- typeAliases别名处理器 :
这里我们也可以使用@Alias注解直接为实体起别名 :
注意点:MyBatis已经为许多常见的 Java 类型内建了相应的类型别名。它们都是大小写不敏感的,我们在起别名的时候千万不要占用已有的别名。
-
typeHandlers 类型处理器
无论是 MyBatis 在预处理语句(PreparedStatement)中设置一个参数时,还是从结果集中取出一个值时, 都会用类型处理器将获取的值以合适的方式转换成 Java 类型。
除了使用已有的类型处理器, 我们还可以自定义类型处理器 :
1)、实现org.apache.ibatis.type.TypeHandler接口或者继承org.apache.ibatis.type.BaseTypeHandler
2)、指定其映射某个JDBC类型(可选操作)
3)、在mybatis全局配置文件中注册 -
plugins插件
我们可以通过插件来修改MyBatis的一些核心行为。插件通过动态代理机制,可以介入四大对象的任何一个方法的执行- Executor (update, query, flushStatements, commit, rollback,getTransaction, close, isClosed)
- ParameterHandler (getParameterObject, setParameters)
- ResultSetHandler (handleResultSets, handleOutputParameters)
- StatementHandler (prepare, parameterize, batch, update, query)
-
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>
-
databaseIdProvider 数据库厂商标识
MyBatis 可以根据不同的数据库厂商执行不同的语句。
上面在xml中配置完后我们就可以在sql映射文件指定了 :<!-- 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>
这样查询数据表就会从oracle中查询了
-
MyBatis匹配规则如下:
1、如果没有配置databaseIdProvider标签,那么databaseId=null
2、如果配置了databaseIdProvider标签,使用标签配置的name去匹配数据库信息,匹配上设置databaseId=配置指定的值,否则依旧为null
3、如果databaseId不为null,他只会找到配置databaseId的sql语句
4、MyBatis 会加载不带 databaseId 属性和带有匹配当前数据库databaseId 属性的所有语句。如果同时找到带有 databaseId 和不带databaseId 的相同语句,则后者会被舍弃。
-
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