Spring Boot+MySQL+Spring Data JPA一个Web的Demo

Stella981
• 阅读 664

2020.06.23 更新

1 概述

一个简单的web项目配合MySQL+Hibernate+Tomcat的简单示例demo,很容易在此基础上扩展成自己的项目.

2 创建工程

笔者IDE为IntelliJ IDEA,新建一个工程,选择Spring Initalizer:

Spring Boot+MySQL+Spring Data JPA一个Web的Demo

下一步的话由于需要部署到服务器上面,选择了war.不需要的话可以选择jar.

Spring Boot+MySQL+Spring Data JPA一个Web的Demo

选择Spring Web+Spring Data JPA+MySQL Driver.

Spring Boot+MySQL+Spring Data JPA一个Web的Demo

Spring Boot+MySQL+Spring Data JPA一个Web的Demo

Spring Boot+MySQL+Spring Data JPA一个Web的Demo

然后完成即可,首次运行的话配置依赖需要一点时间,请耐心等待.

3 配置数据源

配置数据源分为两部分,一部分是建表与建用户,另一部分是在application.properties中配置的.

3.1 创建库与用户

create database test;

注意这里不用创建表了,因为Hibernate从实体类自动创建一个同名的表.

接着创建用户:

create user 'db'@'%' identified by 'xxxxx';

3.2 用户授权

grant all on test.* to 'db'@'%';

这里建议授权all,因为后面Hibernate会用到建表权限,不能仅仅授权增删查改.

3.3 配置application.properties

配置四个属性:

spring.jpa.hibernate.ddl-auto=
spring.datasource.url=
spring.datasource.username=
spring.datasource.password=

第一个属性是可以取值

  • none:none是对MySQL的默认值,不会改变数据库结构.
  • update:Hibernate会根据给出的实体类去改变数据库.
  • create:创建数据库但是不会在关闭的时候删除.
  • create-drop:创建数据库,当SessionFactory关闭时删除数据库.这个是H2与其他嵌入式数据库的默认选项.

第一次运行时必须设置为update或create,因为还不知道确切的实体类,第一次运行后,可以设置为update或none.

url的话对于MySQL来说是

jdbc:mysql://ip:3306/database

剩下的两个为用户名与密码.

以下是笔者的配置,供参考:

Spring Boot+MySQL+Spring Data JPA一个Web的Demo

4 实体类

这里创建一个简单的User实体类,需要用到javax中的@Entity,@Id,@GeneratedValue@GenerationType注解.

@Entity用于标识实体类,@Id用于标识主键,@GeneratedValue@GenerationType用于配置主键.

@Entity
public class User {
    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    private Integer id;
    private String name;

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }
}

除了主键之外,可以加上自己想要的属性与setter和getter,Hibernate会自动将实体类制作成一个数据表.

5 持久层

创建Repository保存用户记录.需要继承CrudRepository<T,ID>,第一个类型为实体类,第二个类型为主键类型.

public interface UserRepository extends CrudRepository<User,Integer> {}

6 控制层

控制层用于控制HTTP请求,在控制器中可以配置不同的路径实现不同的操作.

@Controller
@RequestMapping(path = "/demo")
public class MainController {
    @Autowired
    private UserRepository userRepository;
    
    @PostMapping(path = "/add")
    public @ResponseBody String addNewUser(@RequestParam String name)
    {
        User user = new User();
        user.setName(name);
        userRepository.save(user);
        return "Saved.";
    }
    
    @GetMapping(path = "/all")
    public @ResponseBody Iterable<User> getAllUsers()
    {
        return userRepository.findAll();
    }
}
  • @RequestMapping中的值表示URL以此值开头
  • @PostMapping是仅处理POST请求的路径
  • @ResponseBody表示返回的类型
  • @RequestParam表示一个从GET或POST中获取的参数
  • getAllUsers()会返回一个JSON或者xml

7 IDE上测试

首先输入:

localhost:8080/demo/all

由于先前已经有一行数据所以有显示.

Spring Boot+MySQL+Spring Data JPA一个Web的Demo

否则的话应该显示为[].

接下来可以添加数据:

curl localhost:8080/demo/add -d name=123

回应:

Spring Boot+MySQL+Spring Data JPA一个Web的Demo

接下来可以选择再次查看:

Spring Boot+MySQL+Spring Data JPA一个Web的Demo

再看看数据库:

Spring Boot+MySQL+Spring Data JPA一个Web的Demo

8 打包发布

Build->Build Artifacts.

Spring Boot+MySQL+Spring Data JPA一个Web的Demo

Spring Boot+MySQL+Spring Data JPA一个Web的Demo

Build即可.

然后会在项目目录的target下有一个WAR文件,就是这个了.

Spring Boot+MySQL+Spring Data JPA一个Web的Demo

改名字放到Tomcat的webapps下,比如笔者改成了demo.war:

Spring Boot+MySQL+Spring Data JPA一个Web的Demo

接着可以去访问了,注意路径,这里的路径是WAR的路径加上@RequestMapping的路径再加上@PostMapping@GetMapping路径:

Spring Boot+MySQL+Spring Data JPA一个Web的Demo

9 完整代码

如果觉得文章好看,欢迎点赞。

同时欢迎关注微信公众号:氷泠之路。

Spring Boot+MySQL+Spring Data JPA一个Web的Demo

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Wesley13 Wesley13
3年前
java将前端的json数组字符串转换为列表
记录下在前端通过ajax提交了一个json数组的字符串,在后端如何转换为列表。前端数据转化与请求varcontracts{id:'1',name:'yanggb合同1'},{id:'2',name:'yanggb合同2'},{id:'3',name:'yang
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
4个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Java修道之路,问鼎巅峰,我辈代码修仙法力齐天
<center<fontcolor00FF7Fsize5face"黑体"代码尽头谁为峰,一见秃头道成空。</font<center<fontcolor00FF00size5face"黑体"编程修真路破折,一步一劫渡飞升。</font众所周知,编程修真有八大境界:1.Javase练气筑基2.数据库结丹3.web前端元婴4.Jav
Wesley13 Wesley13
3年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Stella981 Stella981
3年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
10个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这