springboot 整合 mybatis 问题
时间: 2024-12-06 22:14:54 浏览: 16
Spring Boot 整合 MyBatis 是一个常见的开发场景,MyBatis 是一个优秀的持久层框架,它支持自定义 SQL、存储过程以及高级映射。Spring Boot 提供了快速搭建项目的功能,结合 MyBatis 可以快速实现数据持久化功能。以下是 Spring Boot 整合 MyBatis 的基本步骤:
### 1. 创建 Spring Boot 项目
首先,创建一个 Spring Boot 项目,可以使用 Spring Initializr(https://start.spring.io/)来生成项目结构。
### 2. 添加依赖
在 `pom.xml` 文件中添加 MyBatis 和数据库驱动(如 MySQL)的依赖:
```xml
<dependencies>
<!-- Spring Boot Starter -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
</dependency>
<!-- MyBatis Starter -->
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>2.2.0</version>
</dependency>
<!-- MySQL Driver -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>
<!-- Other Dependencies -->
</dependencies>
```
### 3. 配置数据库连接
在 `application.properties` 或 `application.yml` 文件中配置数据库连接信息:
```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
mybatis.mapper-locations=classpath:mapper/*.xml
mybatis.type-aliases-package=com.example.demo.entity
```
### 4. 创建实体类和 Mapper 接口
创建实体类和对应的 Mapper 接口:
```java
// User.java
public class User {
private Long id;
private String name;
private String email;
// Getters and Setters
}
// UserMapper.java
@Mapper
public interface UserMapper {
@Select("SELECT * FROM users WHERE id = #{id}")
User findById(Long id);
@Insert("INSERT INTO users(name, email) VALUES(#{name}, #{email})")
void insert(User user);
// Other methods
}
```
### 5. 创建 Service 和 Controller
创建 Service 和 Controller 来调用 Mapper 方法:
```java
// UserService.java
@Service
public class UserService {
@Autowired
private UserMapper userMapper;
public User getUserById(Long id) {
return userMapper.findById(id);
}
public void addUser(User user) {
userMapper.insert(user);
}
// Other methods
}
// UserController.java
@RestController
@RequestMapping("/users")
public class UserController {
@Autowired
private UserService userService;
@GetMapping("/{id}")
public User getUser(@PathVariable Long id) {
return userService.getUserById(id);
}
@PostMapping
public void addUser(@RequestBody User user) {
userService.addUser(user);
}
// Other methods
}
```
### 6. 启动应用
启动 Spring Boot 应用,访问相应的接口进行测试。
阅读全文