MyBatis 是一个优秀的持久层框架,它对 JDBC 的操作数据库过程进行了封装,使得我们可以用 XML 或注解来配置和原始映射,将接口和 Java 的 POJOs(Plain Old Java Objects,简单的Java对象)映射成数据库中的记录。下面,我们就来详细探讨如何轻松上手 MyBatis,并掌握其在 Java 开发中的实战应用。
MyBatis 的核心概念
在开始实战之前,了解 MyBatis 的核心概念是至关重要的。
1. SQL 映射文件
MyBatis 使用 XML 文件来配置 SQL 语句,这使得 SQL 与 Java 代码分离,便于管理和维护。
2. 映射器(Mapper)
映射器是 MyBatis 的核心,它定义了 SQL 语句和 Java 代码之间的关系。
3. 实体类(POJO)
实体类用来表示数据库中的表结构,MyBatis 将 SQL 结果集映射到实体类中。
4. 映射器接口
映射器接口定义了映射器的操作方法,MyBatis 通过代理模式生成代理对象,实现方法调用。
安装与配置 MyBatis
1. 添加依赖
首先,需要在项目的 pom.xml 文件中添加 MyBatis 的依赖:
<dependencies>
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>版本号</version>
</dependency>
<!-- 其他依赖,如数据库连接池、数据库驱动等 -->
</dependencies>
2. 配置 MyBatis
创建 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/数据库名"/>
<property name="username" value="用户名"/>
<property name="password" value="密码"/>
</dataSource>
</environment>
</environments>
<!-- 配置映射文件 -->
<mappers>
<mapper resource="com/example/mapper/UserMapper.xml"/>
</mappers>
</configuration>
创建映射器接口
在 Java 中创建一个接口,定义要执行的操作方法。
public interface UserMapper {
User getUserById(Integer id);
}
编写 SQL 映射文件
在对应的 mapper 目录下创建 XML 文件,配置 SQL 语句和映射关系。
<!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="getUserById" resultType="com.example.entity.User">
SELECT * FROM user WHERE id = #{id}
</select>
</mapper>
使用 MyBatis
通过 SqlSessionFactoryBuilder 创建 SqlSessionFactory,再通过 SqlSessionFactory 创建 SqlSession,最后通过 SqlSession 执行映射器接口中的方法。
String resource = "mybatis-config.xml";
InputStream inputStream = Resources.getResourceAsStream(resource);
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
try (SqlSession sqlSession = sqlSessionFactory.openSession()) {
UserMapper mapper = sqlSession.getMapper(UserMapper.class);
User user = mapper.getUserById(1);
System.out.println(user);
}
实战案例:图书管理系统
下面是一个简单的图书管理系统的实战案例,使用 MyBatis 实现图书的增删改查功能。
1. 创建数据库表
CREATE TABLE book (
id INT PRIMARY KEY AUTO_INCREMENT,
name VARCHAR(50),
author VARCHAR(50),
price DECIMAL(10, 2)
);
2. 实体类
public class Book {
private Integer id;
private String name;
private String author;
private BigDecimal price;
// 省略 getter 和 setter 方法
}
3. 映射器接口
public interface BookMapper {
Book getBookById(Integer id);
void addBook(Book book);
void updateBook(Book book);
void deleteBook(Integer id);
}
4. 映射文件
<mapper namespace="com.example.mapper.BookMapper">
<select id="getBookById" resultType="com.example.entity.Book">
SELECT * FROM book WHERE id = #{id}
</select>
<insert id="addBook">
INSERT INTO book (name, author, price) VALUES (#{name}, #{author}, #{price})
</insert>
<update id="updateBook">
UPDATE book SET name = #{name}, author = #{author}, price = #{price} WHERE id = #{id}
</update>
<delete id="deleteBook">
DELETE FROM book WHERE id = #{id}
</delete>
</mapper>
5. 使用 MyBatis
// 省略数据库配置和获取 SqlSessionFactory 的代码
try (SqlSession sqlSession = sqlSessionFactory.openSession()) {
BookMapper mapper = sqlSession.getMapper(BookMapper.class);
// 查询图书
Book book = mapper.getBookById(1);
// 添加图书
Book newBook = new Book();
newBook.setName("新图书");
newBook.setAuthor("新作者");
newBook.setPrice(new BigDecimal("39.99"));
mapper.addBook(newBook);
// 更新图书
book.setName("更新后的图书");
mapper.updateBook(book);
// 删除图书
mapper.deleteBook(1);
}
通过以上步骤,我们就可以轻松地使用 MyBatis 实现图书管理系统的基本功能。在实际项目中,可以根据需求进一步完善和扩展功能。希望这个实战指南能帮助你更好地掌握 MyBatis。
