MyBatis 是一个优秀的持久层框架,它消除了几乎所有的 JDBC 代码和手动设置参数以及获取结果集的过程。MyBatis 可以使用简单的 XML 或注解用于配置和原始映射,将接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java对象)映射成数据库中的记录。
MyBatis 简介
MyBatis 是一个半自动化的持久层框架,它消除了大部分的 JDBC 代码,并且提供了自动映射数据库记录到 Java 对象的功能。MyBatis 的设计哲学是“约定大于配置”,这意味着大多数情况下,你只需要配置很少的 XML 或注解即可。
为什么选择 MyBatis?
- 简化 JDBC 操作:MyBatis 自动处理了数据库连接、事务管理和结果集的转换。
- 灵活的映射:MyBatis 支持复杂的映射,如关联、嵌套查询等。
- 易于扩展:MyBatis 提供了插件机制,可以轻松扩展框架的功能。
环境搭建
1. 创建 Maven 项目
首先,你需要在 IDE 中创建一个新的 Maven 项目。在 pom.xml 文件中添加以下依赖:
<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.26</version>
</dependency>
</dependencies>
2. 配置数据库
在 application.properties 文件中配置数据库连接信息:
# 数据库连接信息
spring.datasource.url=jdbc:mysql://localhost:3306/mydb?useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTC
spring.datasource.username=root
spring.datasource.password=root
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
创建 MyBatis 映射文件
在 src/main/resources 目录下创建一个名为 mapper 的文件夹,并在其中创建一个 XML 文件,例如 UserMapper.xml。
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.example.mapper.UserMapper">
<select id="selectById" resultType="com.example.entity.User">
SELECT * FROM user WHERE id = #{id}
</select>
</mapper>
创建 MyBatis 映射接口
在 src/main/java 目录下创建一个与映射文件同名的接口,例如 UserMapper.java。
package com.example.mapper;
import com.example.entity.User;
import org.apache.ibatis.annotations.Select;
public interface UserMapper {
@Select("SELECT * FROM user WHERE id = #{id}")
User selectById(Integer id);
}
使用 MyBatis
在 Java 应用程序中,你可以通过以下方式使用 MyBatis:
package com.example.service;
import com.example.mapper.UserMapper;
import com.example.entity.User;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
public class UserService {
private SqlSessionFactory sqlSessionFactory;
public UserService() {
sqlSessionFactory = new SqlSessionFactoryBuilder().build();
}
public User getUserById(Integer id) {
try (SqlSession session = sqlSessionFactory.openSession()) {
UserMapper userMapper = session.getMapper(UserMapper.class);
return userMapper.selectById(id);
}
}
}
总结
通过以上步骤,你已经成功地在 Java 应用程序中实现了 MyBatis 的基本操作。MyBatis 的强大之处在于其灵活性和扩展性,你可以根据实际需求进行配置和扩展。希望这篇指南能帮助你快速上手 MyBatis。
