当前位置: 首页 > news >正文

springboot简单应用

快速开发Springboot项目实现简单的增删改查,前期需要准备:idea与postman安装 Maven,MySQL(8),JDK(21)

 目录


前言

springboot 使用3.0+版本,JDK使用21,MySQL使用8版本 开发环境IDEA使用2024版本

springboot内嵌了Tomcat,包含spring框架,提供starter 简化Maven配置。这里直接使用JPA作为ORM,不引入mybatis。CRUD采用rest(@PostMapping,@GetMapping("/{userId}",@PutMapping,@DeleteMapping("/{userId}")形式)风格。


相关代码组织结构:controller service repository(dao) pojo(entity) exception等

一、Spring Boot项目创建

 在IDEA中点击 NEW->Project->Spring Boot 开始创建 Spring Boot 项目,Type选择Maven,JDK版本选择21,相关配置如图:

点击Next后选择Web中的Spring Web,SQL中的Spring Data JPA  和MySQL Driver后点击create

在本测试项目中,直接使用JPA作为DAO层技术支撑。 

二、Spring Boot 简单增删改查

1.开发前相关文件配置

新建项目首先确定各个层级代码包名,之后编辑对应propertIes文件

application.properties编辑信息(state_owned_assets_supervise是自建数据库名):

spring.application.name=Accountability
# 默认端口号8080
server.port=8088 
spring.datasource.url=jdbc:mysql://localhost:3306/state_owned_assets_supervise?serverTimezone=UTC
spring.datasource.username=root
spring.datasource.password=123456
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver#show
spring.jpa.show-sql=true
#format_sql
spring.jpa.properties.hibernate.format_sql=true
#auto update db table struct
spring.jpa.hibernate.ddl-auto=update

相关项目代码结构如图: 

 

 

2.编辑相关代码

直接点击启动 AccountabilityApplication类

相关代码结构如图:

在三层模型中,使用repository链接数据库对数据CRUD,之后Service层调用数据访问层进行组合,controller层调用Service层获得结果后返回给前台。 

由于使用的是JPA可以直接新建实体类通过实体类自动在MySQL中建表。代码如下:

package org.jac.accountability.pojo;import jakarta.persistence.*;@Table(name = "db_user")
@Entity
public class User {@Id@GeneratedValue(strategy = GenerationType.IDENTITY)@Column(name = "user_id")private  Integer userId;@Column(name = "user_name")private  String userName;private  String password;private  String email;public Integer getUserId() {return userId;}public void setUserId(Integer userId) {this.userId = userId;}public String getUserName() {return userName;}public void setUserName(String userName) {this.userName = userName;}public String getPassword() {return password;}public void setPassword(String password) {this.password = password;}public String getEmail() {return email;}public void setEmail(String email) {this.email = email;}@Overridepublic String toString() {return "User{" +"userId=" +userId+"userName" + userName+"password" +password+"email" +email+"}";}
}

相关注解:  

@Table(name = "db_user")  MySQL数据库中对应实体类名称为 db_user
@Entity 表明实体类
@Id  表明该ID字段为主键
@GeneratedValue(strategy = GenerationType.IDENTITY)  主键ID自增策略
@Column(name = "user_id") MySQL数据库字段使用蛇形命名,需要变更Java类中命名方式

2.1 编写controller层

2.2编写service层

 


总结

 

http://www.lryc.cn/news/532769.html

相关文章:

  • 【DeepSeek】DeepSeek小模型蒸馏与本地部署深度解析DeepSeek小模型蒸馏与本地部署深度解析
  • C#项目引用VB.NET 类库项目,生成一个EXE,这是什么原理
  • qt使用MQTT协议连接阿里云demo
  • HTML中的图片标签详解及路径使用【学术投稿-第五届环境资源与能源工程国际学术会议(ICEREE 2025)】
  • 【低功耗 Power 学习专栏 -- Power domian 和 power rail】
  • PythonStyle MVC 开发框架
  • RTOS基础(TODO)
  • 八、Spring Boot 日志详解
  • Java实战经验分享
  • 前端控制器模式
  • Linux之安装docker
  • BUUCTF_XSS-Lab
  • springBoot使用
  • DS图(中)(19)
  • Vue Dom截图插件,截图转Base64 html2canvas
  • Unity3D仿星露谷物语开发小结1
  • graylog初体验
  • 15.PPT:文静-云计算行业发展【29】
  • 高端入门:Ollama 本地高效部署DeepSeek模型深度搜索解决方案
  • MFC 的 CListCtrl 控件,使用SetItemState 方法来设置选中某个 item,如何达到效果和鼠标点击一致
  • 一文读懂:TCP网络拥塞的应对策略与方案
  • 深度整理总结MySQL——子查询的工作原理
  • 20240824 美团 笔试
  • Windows图形界面(GUI)-QT-C/C++ - QT 文本编辑控件详解
  • IDEA中Resolving Maven dependencies卡着不动解决方案
  • go数据结构学习笔记
  • 【后端开发】系统设计101——Devops,Git与CICD,云服务与云原生,Linux,安全性,案例研究(30张图详解)
  • Google地图瓦片爬虫——进阶版
  • 免费windows pdf编辑工具
  • 解锁C#数据校验:从基础到实战的进阶之路