Mybatis_第四部分:Mybatis配置⽂件深⼊

本文详细介绍了MyBatis的核心配置文件SqlMapConfig.xml,包括environments标签中的事务管理器(JDBC和MANAGED)和数据源(UNPOOLED,POOLED,JNDI)的配置。此外,还讲解了mapper标签、Properties标签和typeAliases标签的用途。文章重点讨论了动态SQL的使用,如条件查询和使用foreach进行SQL拼接,以及SQL片段的抽取和重用,展示了如何根据业务需求构建灵活的查询语句。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Mybatis_第四部分:Mybatis配置⽂件深⼊

4.1 核⼼配置⽂件SqlMapConfig.xml

4.1.1 MyBatis核⼼配置⽂件层级关系

 

4.2 MyBatis常⽤配置解析

1)environments标签

数据库环境的配置,⽀持多环境配置

 

其中,事务管理器( transactionManager )类型有两种:
•JDBC :这个配置就是直接使⽤了 JDBC 的提交和回滚设置,它依赖于从数据源得到的连接来管理事务作⽤域。
•MANAGED :这个配置⼏乎没做什么。它从来不提交或回滚⼀个连接,⽽是让容器来管理事务的整个⽣命周期(⽐如 JEE 应⽤服务器的上下⽂)。 默认情况下它会关闭连接,然⽽⼀些容器并不希望这样,因此需要将 closeConnection 属性设置为 false 来阻⽌它默认的关闭⾏为。
其中,数据源( dataSource )类型有三种:
•UNPOOLED :这个数据源的实现只是每次被请求时打开和关闭连接。
•POOLED :这种数据源的实现利⽤ 的概念将 JDBC 连接对象组织起来。 •JNDI :这个数据源的实现是为了能在如 EJB 或应⽤服务器这类容器中使⽤,容器可以集中或在外部配
置数据源,然后放置⼀个 JNDI 上下⽂的引⽤。

2)mapper标签

该标签的作⽤是加载映射的,加载⽅式有如下⼏种:
使⽤相对于类路径的资源引⽤,例如:
<mapper resource="org/mybatis/builder/AuthorMapper.xml"/>
使⽤完全限定资源定位符( URL ),例如:
<mapper url="file:///var/mappers/AuthorMapper.xml"/>
使⽤映射器接⼝实现类的完全限定类名,例如:
<mapper class="org.mybatis.builder.AuthorMapper"/>
将包内的映射器接⼝实现全部注册为映射器,例如:
<package name="org.mybatis.builder"/>

3)Properties标签

实际开发中,习惯将数据源的配置信息单独抽取成⼀个 properties ⽂件,该标签可以加载额外配置的 properties⽂件

 

4)typeAliases标签

类型别名是为 Java 类型设置⼀个短的名字。原来的类型名称配置如下

 

配置 typeAliases ,为 com.lagou.domain.User 定义别名为 user

 

上⾯我们是⾃定义的别名, mybatis 框架已经为我们设置好的⼀些常⽤的类型的别名

 

4.2 映射配置⽂件mapper.xml

动态 sql 语句
动态 sql 语句概述
Mybatis 的映射⽂件中,前⾯我们的 SQL 都是⽐较简单的,有些时候业务逻辑复杂时,我们的 SQL 是动态变化的,此时在前⾯的学习中我们的 SQL 就不能满⾜要求了。
参考的官⽅⽂档,描述如下:

 

动态 SQL
我们根据实体类的不同取值,使⽤不同的 SQL 语句来进⾏查询。⽐如在 id 如果不为空时可以根据 id 查询,如果username 不同空时还要加⼊⽤户名作为条件。这种情况在我们的多条件组合查询中经常会碰到。
<select id = "findByCondition" parameterType = "user" resultType = "user" >
select * from User
<where>
<if test = "id!=0" >
and id=#{id}
</if>
<if test = "username!=null" >
and username=#{username}
</if>
</where>
</select>
当查询条件 id username 都存在时,控制台打印的 sql 语句如下:
… … …
// 获得 MyBatis 框架⽣成的 UserMapper 接⼝的实现类
UserMapper userMapper = sqlSession . getMapper ( UserMapper . class );
User condition = new User ();
condition . setId ( 1 );
condition . setUsername ( "lucy" );
User user = userMapper . findByCondition ( condition );
… … …

 

当查询条件只有 id 存在时,控制台打印的 sql 语句如下:
… … …
// 获得 MyBatis 框架⽣成的 UserMapper 接⼝的实现类
UserMapper userMapper = sqlSession . getMapper ( UserMapper . class );
User condition = new User ();
condition . setId ( 1 );
User user = userMapper . findByCondition ( condition );
… … …

 

动态 SQL
循环执⾏ sql 的拼接操作,例如: SELECT * FROM USER WHERE id IN (1,2,5)
<select id = "findByIds" parameterType = "list" resultType = "user" >
select * from User
<where>
<foreach collection = "list" open = "id in(" close = ")" item = "id"
separator = "," >
#{id}
</foreach>
</where>
</select>
测试代码⽚段如下:
… … …
// 获得 MyBatis 框架⽣成的 UserMapper 接⼝的实现类
UserMapper userMapper = sqlSession . getMapper ( UserMapper . class );
int [] ids = new int []{ 2 , 5 };
List < User > userList = userMapper . findByIds ( ids );
System . out . println ( userList );
… … …

 

foreach 标签的属性含义如下:
标签⽤于遍历集合,它的属性:
•collection :代表要遍历的集合元素,注意编写时不要写 #{}
•open :代表语句的开始部分
•close :代表结束部分
•item :代表遍历集合的每个元素,⽣成的变量名
•sperator :代表分隔符
SQL ⽚段抽取
Sql 中可将重复的 sql 提取出来,使⽤时⽤ include 引⽤即可,最终达到 sql 重⽤的⽬的
<!-- 抽取 sql ⽚段简化编写 -->
<sql id = "selectUser" select * from User </sql>
<select id = "findById" parameterType = "int" resultType = "user" >
<include refid = "selectUser" ></include> where id=#{id}
</select>
<select id = "findByIds" parameterType = "list" resultType = "user" >
<include refid = "selectUser" ></include>
<where>
<foreach collection = "array" open = "id in(" close = ")" item = "id"
separator = "," >
#{id}
</foreach>
</where>
</select>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值