在Spring Boot中整合MyBatis的配置流程分为以下几个步骤:
1. 添加依赖:
首先,您需要在项目的`pom.xml`文件中添加MyBatis和数据库驱动的依赖。通常,您会使用MyBatis的Spring Boot Starter依赖来简化配置。例如,如果您使用MySQL数据库,可以添加以下依赖:
```xml
XML<dependencies> <!-- MyBatis Spring Boot Starter --> <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>2.2.0</version> <!-- 根据您的需求选择合适的版本 --> </dependency> <!-- MySQL数据库驱动 --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>8.0.27</version> <!-- 根据您的MySQL版本选择合适的驱动版本 --> </dependency> </dependencies>
```
2. 配置数据源:
在`application.properties`或`application.yml`文件中配置数据库连接信息,包括URL、用户名和密码。例如:
使用`application.properties`配置:
```properties
spring.datasource.url=jdbc:mysql://localhost:3306/your_database
spring.datasource.username=your_username
spring.datasource.password=your_password
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
```
或使用`application.yml`配置:
```yaml
spring:
datasource:
url: jdbc:mysql://localhost:3306/your_database
username: your_username
password: your_password
driver-class-name: com.mysql.cj.jdbc.Driver
```
3. 创建Mapper接口:
创建DAO(数据访问对象)接口,这些接口用于定义数据库操作方法。通常,您会在接口上使用`@Mapper`注解来告诉MyBatis将其实现为Mapper接口。例如:
```java
javaimport org.apache.ibatis.annotations.Mapper; @Mapper public interface UserMapper { User getUserById(Long id); List<User> getAllUsers(); void insertUser(User user); void updateUser(User user); void deleteUser(Long id); }
```
4. 创建Mapper XML文件:
为每个Mapper接口编写对应的Mapper XML文件,这些文件包含SQL语句和映射规则。Mapper XML文件通常存放在`resources`目录下的`mapper`子目录中。例如,`UserMapper.xml`文件:
```xml
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.demo.dao.UserMapper"> <resultMap id="BaseResultMap" type="com.example.demo.entity.User"> <id column="id" property="id" jdbcType="BIGINT"/> <result column="username" property="username" jdbcType="VARCHAR"/> <!-- 其他字段映射 --> </resultMap> <select id="getUserById" resultMap="BaseResultMap"> SELECT * FROM user WHERE id = #{id} </select> <!-- 其他SQL语句 --> </mapper>
```
5. 配置MyBatis扫描:
在Spring Boot的主应用程序类上添加`@MapperScan`注解,以告诉Spring Boot扫描Mapper接口的包路径。例如:
```java
javaimport org.mybatis.spring.annotation.MapperScan; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; @SpringBootApplication @MapperScan("com.example.demo.dao") // 指定Mapper接口所在的包路径 public class MyApplication { public static void main(String[] args) { SpringApplication.run(MyApplication.class, args); } }
```
6. 使用Mapper:
在您的服务或控制器中注入Mapper接口,然后使用它们来访问数据库。例如:
```java
java@Service public class UserService { private final UserMapper userMapper; @Autowired public UserService(UserMapper userMapper) { this.userMapper = userMapper; } public User getUserById(Long id) { return userMapper.getUserById(id); } // 其他数据库操作方法 }
其余根据你的项目需求和数据库配置进行相应的调整和扩展。
```