MyBatis 是一个优秀的持久层框架,它消除了几乎所有的 JDBC 代码和手动设置参数以及获取结果集的工作。MyBatis 可以使用简单的 XML 或注解用于配置和原始映射,将接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java对象)映射成数据库中的记录。
MyBatis 简介
MyBatis 遵循约定优于配置的原则,通过 XML 或注解的方式将接口和 Java 对象映射到 SQL 语句,从而实现数据库的增删改查操作。MyBatis 的核心是 SQL 映射文件,它定义了 SQL 语句以及与 Java 对象的映射关系。
MyBatis 入门
1. 环境搭建
首先,需要在项目中引入 MyBatis 的依赖。以下是一个简单的 Maven 依赖配置示例:
<dependencies>
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.7</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.22</version>
</dependency>
</dependencies>
2. 配置文件
创建 mybatis-config.xml 配置文件,配置数据库连接信息、事务管理器、映射器等。
<configuration>
<environments default="development">
<environment id="development">
<transactionManager type="JDBC"/>
<dataSource type="POOLED">
<property name="driver" value="com.mysql.cj.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://localhost:3306/mydb?useSSL=false"/>
<property name="username" value="root"/>
<property name="password" value="password"/>
</dataSource>
</environment>
</environments>
<mappers>
<mapper resource="com/example/mapper/UserMapper.xml"/>
</mappers>
</configuration>
3. 映射文件
创建 UserMapper.xml 映射文件,定义 SQL 语句和 Java 对象的映射关系。
<mapper namespace="com.example.mapper.UserMapper">
<select id="selectById" resultType="com.example.entity.User">
SELECT * FROM user WHERE id = #{id}
</select>
</mapper>
4. 接口和实现
创建 UserMapper 接口,定义查询方法。
public interface UserMapper {
User selectById(Integer id);
}
5. 测试
编写测试代码,使用 MyBatis 执行查询操作。
public class MyBatisTest {
public static void main(String[] args) throws IOException {
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(new FileInputStream("src/main/resources/mybatis-config.xml"));
SqlSession sqlSession = sqlSessionFactory.openSession();
try {
UserMapper mapper = sqlSession.getMapper(UserMapper.class);
User user = mapper.selectById(1);
System.out.println(user);
} finally {
sqlSession.close();
}
}
}
MyBatis 高级应用
1. 动态 SQL
MyBatis 支持动态 SQL,可以根据条件动态生成 SQL 语句。
<select id="selectByCondition" resultType="com.example.entity.User">
SELECT * FROM user
<where>
<if test="id != null">
AND id = #{id}
</if>
<if test="name != null">
AND name = #{name}
</if>
</where>
</select>
2. 批量操作
MyBatis 支持批量操作,例如批量插入、批量更新等。
<insert id="batchInsert" parameterType="java.util.List">
INSERT INTO user (name, age) VALUES
<foreach collection="list" item="user" separator=",">
(#{user.name}, #{user.age})
</foreach>
</insert>
3. 缓存
MyBatis 支持一级缓存和二级缓存,可以提高查询效率。
<cache eviction="FIFO" flushInterval="60000" size="512" readOnly="true"/>
总结
MyBatis 是一个功能强大、灵活的持久层框架,可以帮助开发者快速实现数据库操作。通过本文的介绍,相信你已经对 MyBatis 有了一个基本的了解。在实际开发中,你可以根据项目需求选择合适的配置和功能,提高开发效率和代码质量。
