MyBatis简介
MyBatis是一款优秀的Java持久层框架,它消除了几乎所有的JDBC代码和手动设置参数以及获取结果集的过程。MyBatis通过简单的XML或注解用于配置和原始映射,将接口和Java的POJOs(Plain Old Java Objects,普通的Java对象)映射成数据库中的记录。
MyBatis入门
环境搭建
- 添加依赖:在项目的
pom.xml文件中添加MyBatis的依赖。
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.6</version>
</dependency>
- 配置文件:创建
mybatis-config.xml配置文件,配置数据库连接、事务管理等。
<configuration>
<environments default="development">
<environment id="development">
<transactionManager type="JDBC"/>
<dataSource type="POOLED">
<property name="driver" value="com.mysql.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://localhost:3306/mydatabase"/>
<property name="username" value="root"/>
<property name="password" value=""/>
</dataSource>
</environment>
</environments>
<mappers>
<mapper resource="com/example/mapper/UserMapper.xml"/>
</mappers>
</configuration>
- 编写Mapper接口:定义Mapper接口,接口中声明方法对应数据库中的操作。
public interface UserMapper {
User getUserById(int id);
}
- 编写Mapper XML:在对应的Mapper XML文件中编写SQL语句。
<mapper namespace="com.example.mapper.UserMapper">
<select id="getUserById" resultType="com.example.User">
SELECT * FROM users WHERE id = #{id}
</select>
</mapper>
使用MyBatis
- 获取SqlSessionFactory:通过配置文件创建SqlSessionFactory。
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(new Reader(new File("src/main/resources/mybatis-config.xml")));
- 获取SqlSession:通过SqlSessionFactory获取SqlSession。
SqlSession sqlSession = sqlSessionFactory.openSession();
- 执行查询:使用SqlSession执行查询。
User user = sqlSession.selectOne("com.example.mapper.UserMapper.getUserById", 1);
- 提交或回滚事务:完成操作后,提交或回滚事务。
sqlSession.commit();
// 或者
sqlSession.rollback();
- 关闭SqlSession:操作完成后关闭SqlSession。
sqlSession.close();
MyBatis进阶技巧
动态SQL
MyBatis支持动态SQL,允许在运行时构建SQL语句。
- 使用
<if>标签:根据条件判断是否包含SQL片段。
<select id="findActiveBlogWithTitleLike" resultType="Blog">
SELECT * FROM BLOG
WHERE state = ‘ACTIVE’
<if test="title != null">
AND title like #{title}
</if>
</select>
- 使用
<choose>标签:类似于Java中的switch语句。
<select id="findActiveBlogLike" resultType="Blog">
SELECT * FROM BLOG
<where>
<choose>
<when test="title != null">
title like #{title}
</when>
<when test="author != null">
author = #{author}
</when>
<otherwise>
state = ‘ACTIVE’
</otherwise>
</choose>
</where>
</select>
插入和更新
MyBatis提供<insert>和<update>标签来执行插入和更新操作。
- 插入操作:
<insert id="insertUser" parameterType="User">
INSERT INTO users (username, email, age)
VALUES (#{username}, #{email}, #{age})
</insert>
- 更新操作:
<update id="updateUser" parameterType="User">
UPDATE users
SET username = #{username},
email = #{email},
age = #{age}
WHERE id = #{id}
</update>
缓存
MyBatis提供了两种类型的缓存:一级缓存和二级缓存。
一级缓存:在同一个SqlSession中,同一个Mapper的同一个查询只会查询一次数据库。
二级缓存:在同一个SqlSession工厂中,同一个Mapper的同一个查询会被缓存。
<cache eviction="FIFO" flushInterval="60000" size="512" readOnly="true"/>
总结
MyBatis作为一款高效的Java持久层框架,能够帮助开发者简化数据库操作,提高开发效率。通过本文的介绍,相信你已经对MyBatis有了初步的了解。在后续的学习和实践中,不断探索和尝试,相信你会掌握更多高级技巧。
