MyBatis 是一个优秀的持久层框架,它消除了几乎所有的 JDBC 代码和手动设置参数以及获取结果集的工作。MyBatis 可以使用简单的 XML 或注解用于配置和原始映射,将接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java对象)映射成数据库中的记录。
MyBatis 的用法
1. 添加依赖
首先,需要在项目的 pom.xml 文件中添加 MyBatis 的依赖。
<dependencies>
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.6</version>
</dependency>
<dependency>
<groupId>org.mybatis.caches</groupId>
<artifactId>mybatis-redis</artifactId>
<version>1.0.0</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>5.3.10</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jdbc</artifactId>
<version>5.3.10</version>
</dependency>
</dependencies>
2. 配置文件
接下来,需要创建一个配置文件 mybatis-config.xml,用于配置 MyBatis 的运行环境。
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<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=""/>
</dataSource>
</environment>
</environments>
<mappers>
<mapper resource="com/example/mapper/UserMapper.xml"/>
</mappers>
</configuration>
3. 创建 Mapper 接口
在 com.example.mapper 包下创建一个 UserMapper 接口。
package com.example.mapper;
public interface UserMapper {
List<User> findAll();
}
4. 创建 Mapper 映射文件
在 com/example/mapper 包下创建一个 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="findAll" resultType="com.example.entity.User">
SELECT * FROM user
</select>
</mapper>
5. 使用 MyBatis
在 com.example.service 包下创建一个 UserService 类,用于操作数据库。
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;
import java.util.List;
public class UserService {
private static SqlSessionFactory sqlSessionFactory;
static {
try {
sqlSessionFactory = new SqlSessionFactoryBuilder().build(
Resources.getResourceAsStream("mybatis-config.xml"));
} catch (IOException e) {
e.printStackTrace();
}
}
public List<User> findAll() {
try (SqlSession session = sqlSessionFactory.openSession()) {
UserMapper mapper = session.getMapper(UserMapper.class);
return mapper.findAll();
}
}
}
MyBatis 的优势
1. 简化开发
MyBatis 消除了大部分的 JDBC 代码,让开发者能够更加专注于业务逻辑。
2. 灵活配置
MyBatis 支持使用 XML 或注解进行配置,方便开发者根据需求进行调整。
3. 高度可扩展
MyBatis 提供了丰富的插件机制,方便开发者进行自定义扩展。
4. 支持多种数据库
MyBatis 支持多种数据库,如 MySQL、Oracle、SQL Server 等。
5. 社区活跃
MyBatis 拥有活跃的社区,可以方便地获取技术支持和资源。
总之,MyBatis 是一个功能强大、易于使用的持久层框架,适合各种规模的项目。希望本文能帮助您更好地了解 MyBatis 的用法和优势。
