MyBatis 是一个优秀的持久层框架,它对JDBC进行了封装,简化了数据库操作。本文将带你从MyBatis的基础开始,逐步深入,掌握高级应用技巧。
一、MyBatis入门
1.1 MyBatis简介
MyBatis 允许你使用简单的XML或注解用于配置和原始映射,将接口和Java的POJOs(Plain Old Java Objects,简单的Java对象)映射成数据库中的记录。
1.2 环境搭建
- 下载MyBatis: 从官网下载最新版本的MyBatis压缩包。
- 添加依赖: 在项目的
pom.xml文件中添加MyBatis的依赖。<dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>3.5.6</version> </dependency> - 配置MyBatis: 在项目中创建
mybatis-config.xml配置文件,配置数据库连接信息等。
1.3 编写Mapper接口
Mapper接口定义了数据库操作的方法,MyBatis通过XML文件或注解的方式将接口方法与SQL语句进行映射。
public interface UserMapper {
User getUserById(int id);
}
1.4 编写XML映射文件
在src/main/resources目录下创建对应的XML映射文件,例如UserMapper.xml。
<mapper namespace="com.example.mapper.UserMapper">
<select id="getUserById" resultType="com.example.User">
SELECT * FROM user WHERE id = #{id}
</select>
</mapper>
1.5 使用MyBatis
创建MyBatis的SqlSessionFactory,使用SqlSessionFactory创建SqlSession,通过SqlSession执行数据库操作。
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(Resources.getResourceAsReader("mybatis-config.xml"));
SqlSession sqlSession = sqlSessionFactory.openSession();
User user = sqlSession.selectOne("com.example.mapper.UserMapper.getUserById", 1);
sqlSession.close();
二、MyBatis高级应用
2.1 动态SQL
MyBatis支持动态SQL,可以编写条件、循环、选择等动态SQL语句。
<select id="getUserByCondition" resultType="com.example.User">
SELECT * FROM user
<where>
<if test="id != null">
AND id = #{id}
</if>
<if test="name != null">
AND name = #{name}
</if>
</where>
</select>
2.2 一对一、一对多、多对多关联
MyBatis支持一对一、一对多、多对多关联查询。
<!-- 一对一关联查询 -->
<select id="getOrderDetailById" resultType="com.example.OrderDetail">
SELECT od.* FROM order_detail od
LEFT JOIN order o ON od.order_id = o.id
WHERE o.id = #{id}
</select>
<!-- 一对多关联查询 -->
<select id="getOrderItemsById" resultType="com.example.OrderItem">
SELECT * FROM order_item WHERE order_id = #{id}
</select>
<!-- 多对多关联查询 -->
<select id="getUsersByRoleIds" resultType="com.example.User">
SELECT u.* FROM user u
INNER JOIN user_role ur ON u.id = ur.user_id
WHERE ur.role_id IN
<foreach item="roleId" collection="roleIds" open="(" separator="," close=")">
#{roleId}
</foreach>
</select>
2.3 事务管理
MyBatis支持声明式事务管理,使用@Transactional注解即可。
@Transactional
public void updateOrder(Order order) {
sqlSession.update("com.example.mapper.OrderMapper.updateOrder", order);
}
2.4 缓存
MyBatis提供了两种缓存机制:一级缓存和二级缓存。
- 一级缓存: 本地缓存,只对当前SqlSession有效。
- 二级缓存: 全局缓存,对整个应用程序有效。
<cache eviction="FIFO" flushInterval="60000" size="512" readOnly="true"/>
2.5 插件
MyBatis插件可以拦截SQL执行过程中的各个环节,例如执行前、执行后、结果映射等。
public class MyInterceptor implements Interceptor {
public Object intercept(Invocation invocation) throws Throwable {
// 拦截SQL执行过程
return invocation.proceed();
}
}
三、总结
本文从MyBatis入门到高级应用技巧进行了详细的解析,相信你已经对MyBatis有了更深入的了解。在实际开发中,多加练习,不断积累经验,才能更好地运用MyBatis。祝你在Java开发的道路上越走越远!
