IT评测·应用市场-qidao123.com

标题: 在Spring Boot项目中使用MySQL数据库 [打印本页]

作者: 九天猎人    时间: 2024-8-31 11:44
标题: 在Spring Boot项目中使用MySQL数据库
一、弁言

MySQL 是一个广泛使用的开源关系型数据库,而 Spring Boot 则是一个盛行的 Java 框架,提供了快速构建生产级别的独立 Spring 应用的本领。将 MySQL 与 Spring Boot 集成,可以轻松地管理应用的数据存储。本文将先容如何在 Spring Boot 项目中设置和使用 MySQL 数据库。
二、环境预备

1. 安装 MySQL

首先,确保你的体系上已经安装了 MySQL。你可以从MySQL 官方网站下载并安装 MySQL。假如你已经安装好了,可以通过以下命令检查 MySQL 服务是否正在运行:
  1. mysql -u root -p
复制代码
2. 创建数据库和用户

登录 MySQL 后,创建一个数据库和用户供 Spring Boot 项目使用:
  1. CREATE DATABASE my_spring_boot_db;
  2. CREATE USER 'springuser'@'localhost' IDENTIFIED BY 'password';
  3. GRANT ALL PRIVILEGES ON my_spring_boot_db.* TO 'springuser'@'localhost';
  4. FLUSH PRIVILEGES;
复制代码
这里我们创建了一个名为 my_spring_boot_db 的数据库,并为用户 springuser 分配了全部权限。
三、Spring Boot 项目的搭建

1. 创建 Spring Boot 项目

你可以使用 Spring Initializr 快速创建一个 Spring Boot 项目。在Spring Initializr 网站上选择以下设置:

点击“Generate”按钮下载项目模板,并将其解压缩。
2. 添加 MySQL 依赖

在创建的项目中,打开 pom.xml 文件,确认已经包罗以下 MySQL 依赖:
  1. <dependency>
  2.     <groupId>mysql</groupId>
  3.     <artifactId>mysql-connector-java</artifactId>
  4. </dependency>
复制代码
这将使 Spring Boot 可以大概与 MySQL 数据库通信。
四、设置 MySQL 数据库连接

在 src/main/resources 目次下的 application.properties 文件中,添加以下数据库连接设置:
  1. spring.datasource.url=jdbc:mysql://localhost:3306/my_spring_boot_db?useSSL=false&serverTimezone=UTC
  2. spring.datasource.username=springuser
  3. spring.datasource.password=password
  4. spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
  5. # JPA 配置
  6. spring.jpa.hibernate.ddl-auto=update
  7. spring.jpa.show-sql=true
  8. spring.jpa.properties.hibernate.dialect=org.hibernate.dialect.MySQL5Dialect
复制代码
这些设置告诉 Spring Boot 如何连接到 MySQL 数据库,并启用 JPA(Java Persistence API)进行数据访问。
五、创建实体类和数据访问层

1. 创建实体类

在 src/main/java/com/example/demo 目次下创建一个 model 包,并在其中创建一个名为 User 的实体类:
  1. package com.example.demo.model;
  2. import jakarta.persistence.Entity;
  3. import jakarta.persistence.GeneratedValue;
  4. import jakarta.persistence.GenerationType;
  5. import jakarta.persistence.Id;
  6. @Entity
  7. public class User {
  8.     @Id
  9.     @GeneratedValue(strategy = GenerationType.IDENTITY)
  10.     private Long id;
  11.     private String name;
  12.     private String email;
  13.     // Getters and setters
  14. }
复制代码
2. 创建数据访问接口

接下来,在 src/main/java/com/example/demo 目次下创建一个 repository 包,并在其中创建一个名为 UserRepository 的接口:
  1. package com.example.demo.repository;
  2. import com.example.demo.model.User;
  3. import org.springframework.data.jpa.repository.JpaRepository;
  4. import org.springframework.stereotype.Repository;
  5. @Repository
  6. public interface UserRepository extends JpaRepository<User, Long> {
  7. }
复制代码
UserRepository 继承自 JpaRepository,提供了常用的数据库操纵方法,如生存、删除、查找等。
六、编写服务层和控制器

1. 创建服务层

在 src/main/java/com/example/demo 目次下创建一个 service 包,并在其中创建一个名为 UserService 的类:
  1. package com.example.demo.service;
  2. import com.example.demo.model.User;
  3. import com.example.demo.repository.UserRepository;
  4. import org.springframework.beans.factory.annotation.Autowired;
  5. import org.springframework.stereotype.Service;
  6. import java.util.List;
  7. @Service
  8. public class UserService {
  9.     @Autowired
  10.     private UserRepository userRepository;
  11.     public List<User> getAllUsers() {
  12.         return userRepository.findAll();
  13.     }
  14.     public void saveUser(User user) {
  15.         userRepository.save(user);
  16.     }
  17. }
复制代码
2. 创建控制器

末了,在 src/main/java/com/example/demo 目次下创建一个 controller 包,并在其中创建一个名为 UserController 的类:
  1. package com.example.demo.controller;
  2. import com.example.demo.model.User;
  3. import com.example.demo.service.UserService;
  4. import org.springframework.beans.factory.annotation.Autowired;
  5. import org.springframework.web.bind.annotation.*;
  6. import java.util.List;
  7. @RestController
  8. @RequestMapping("/users")
  9. public class UserController {
  10.     @Autowired
  11.     private UserService userService;
  12.     @GetMapping
  13.     public List<User> getAllUsers() {
  14.         return userService.getAllUsers();
  15.     }
  16.     @PostMapping
  17.     public void createUser(@RequestBody User user) {
  18.         userService.saveUser(user);
  19.     }
  20. }
复制代码
七、运行项目并测试

1. 启动应用

你可以通过以下命令运行应用:
  1. mvn spring-boot:run
复制代码
2. 测试 API

应用启动后,可以使用 curl 或 Postman 等工具测试 API。例如,获取全部用户:
  1. curl -X GET http://localhost:8080/users
复制代码
或创建新用户:
  1. curl -X POST http://localhost:8080/users -H "Content-Type: application/json" -d '{"name":"John Doe","email":"john.doe@example.com"}'
复制代码
八、结语

通过本文,你已经相识了如何在 Spring Boot 项目中集成 MySQL 数据库,并通过简单的 API 来管理用户数据。Spring Boot 的简便性和 MySQL 的强大功能结合,使得开发高效且愉快。

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。




欢迎光临 IT评测·应用市场-qidao123.com (https://dis.qidao123.com/) Powered by Discuz! X3.4