myBatis配置解析
文档:https://mybatis.net.cn/configuration.html#settings
1配置核心文件
mybatis-config.xml
MyBatis 的配置文件包含了会深深影响MyBatis行为的设置和属性信息。
1 configuration(配置)
2 properties(属性)
3 settings(设置)
4 typeAliases(类型别名)
5 typeHandlers(类型处理器)
6 objectFactory (对象工厂)
7 plugins(插件)
8 environments(环境配置)
9 environment(环境变量)
10 transactionManager(事务管理器)
11 datasource(数据源)
12 database1dProvider(数据库厂商标识)
13 mappers(映射器)
2环境配置(environments)
MyBatis可以配置成适应多种环境
不过要记住:尽管可以配置多个环境,但每个SqlSessionFactory实例只能选择一种环境。学会使用配置多套运行环境!
Mybatis默认的事务管理器就是JDBC(JDBC/Managed),连接池:POOLED(UNPOOL/POOLES/JNDI)
3属性(properties)
我们可以通过properties属性来实现引用配置文件
这些属性都是可外部配置且可动态替换的,既可以在典型的Java属性文件中配置,亦可通过properties元素的子元素来传递。
db.properties
driver=com.mysql.cj.jdbc.Driver
url=jdbc:mysql://localhost:3306/mybatis?useUnicode=ture&useSSL=true&characterEncoding=UTF-8
username=root
password=123456
核心配置文件,xml文件映入
- 可以映入外部文件
- 同时也可以配置源
- 但是有优先顺序:外部文件比内部配置优先
<!--引入外部文件-->
<properties resource="db.properties">
<property name="username" value="root"/>
<property name="password" value="123456"/>
</properties>
4给类起别名
- 类型别名是为Java类型设置一个短的名字。
- 存在的意义仅在于用来减少类完全限定名的冗余。
在myBatis-config.xnl置文件中插入,就可以在sql.xml文件中使用
<!--给类起别名-->
<typeAliases>
<typeAlias type="pojo.User" alias="User"/>
</typeAliases>
也可以在myBatis-config.xnl置文件中配置指定的包,包下的类就可以直接用在sql.xml文件中使用(首字母小写)
<!--给类起别名-->
<typeAliases>
<package name="pojo"/>
</typeAliases>
实体类较少的时候用第一种,多的时候第二种
第一种可以在DIY别名。第二种不行,但是可以实体类上注解起别名
@Alias( "user")
public class user{
}
5设置
日志实现方式
6映射器
方式一
<mappers>
<mapper resource="XXX/XXX/UserDao.xml"/>
</mappers>
方式二
注意点
- 接口和他的Mapper配置文件必须同名!
- 接口和他的Mapper配置文件必须在同一个包下!(UserMapper接口和UserMapper.xml)
<mappers>
<mapper class="XX.XX.UserDao"/>
</mappers>
方式三
注意点
- 接口和他的Mapper配置文件必须同名!
- 接口和他的Mapper配置文件必须在同一个包下!(UserMapper接口和UserMapper.xml)
<mappers>
<package name="XX.XX"/>
</mappers>
7结果集映射
数据库和实体类字段不一致时,会发生查询结果为NULL情况
方法1:sql语句后加别名
select id,name,pwd password from User;
方法二,Usermapper.xml添加结果集映射
<!--结果集映射-->
<resultMap id="UserMap" type="user">
<!--column数据库中的字段, property实体类中的属性-->
<result column="id" property="id"/>
<result column="name" property="name"/>
<result column="pwd" property="password"/>
</resultMap>
<select id="runSQL" resultMap="UserMap">
select * from myBatis.user;
</select>
- resultMap元素是MyBatis 中最重要最强大的元素
- ResultMap的设计思想是,对于简单的语句根本不需要配置显式的结果映射,而对于复杂一点的语句只需要描述它们的关系就行了。
- ResultMap最优秀的地方在于,虽然你已经对它相当了解了,但是根本就不需要显式地用到他们。
- 如果世界总是这么简单就好了。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?