转载自:https://www.cnblogs.com/juncaoit/p/7789034.html

springBoot的数据库操作

一:操作数据库起步

1.Spring-Data-Jpa

  JPA定义了对象持久化的标准。

  目前实现了有Hibernate,TopLink

2.pom添加依赖

 <dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency> <dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
</dependency>

3.对jps进行配置

spring:
profiles:
active: dev
datasource:
driver-class-name: com.mysql.jdbc.Driver
url: jdbc:mysql://127.0.0.1:3308/people?useSSL=false
username: root
password: 123456
jpa:
hibernate:
ddl-auto: create
show-sql: true

4.新建一个people的数据库

  CREATE DATABASE IF NOT EXISTS yiibaidb DEFAULT CHARSET utf8 COLLATE utf8_general_ci;

  不然,程序会报未发现数据库。

  但是,表不需要新建,这个通过类就可以生成。

5.student的类

  可以映射成数据库的字段。

  Entity注解表示:类对应一个数据库的一个表。

 package com.aspirant.springboot;

 import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id; @Entity
public class Student { @Id
@GeneratedValue
private Integer id;
private String name;
private Integer age; public Student(){ } 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;
} public Integer getAge() {
return age;
} public void setAge(Integer age) {
this.age = age;
}
}

6.自动生成数据库

7.注意点

  配置文件的ddi-auto:create

  意思的每次启动的时候都会把数据库清空。

  

  ddl-auto:update

  如果没有表,会自动创建,但是如果里面有数据,就不会清空数据。

二:操作数据的API

1.新建类(继续使用上面的Student.java类)

2.新建接口

 package com.aspirant.springboot;

 import org.springframework.data.jpa.repository.JpaRepository;

 public interface StudentResitory extends JpaRepository<Student,Integer> {

 }

3.新建controller类  

查询数据库中的所有
 package com.aspirant.springboot;

 import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController; import java.util.List; @RestController
public class StudentController { @Autowired
private StudentResitory studentResitory; /**
* 查询数据库中的所有
* @return
*/
@GetMapping(value = "/hello")
public List<Student> getStuList(){
return studentResitory.findAll();
}
}

4.效果

5.添加一个学生记录

/**
* 添加一个学生记录
*/
@PostMapping(value = "/hello")
public Student addStu(@RequestParam("name") String name,@RequestParam("age") Integer age){
Student stu=new Student();
stu.setName(name);
stu.setAge(age);
return studentResitory.save(stu);
}

6.查询一个人,根据id

 /**
* 查询一个学生,根据字段id
*/
@GetMapping(value = "/hello/{id}")
public Student getStu(@PathVariable("id") Integer id){
return studentResitory.findOne(id);
}

7.更新

 /**
* 更新数据库
*/
@PutMapping(value = "/hello/{id}")
public Student updateStu(@PathVariable("id") Integer id,
@RequestParam("name") String name,
@RequestParam("age") Integer age ){
Student stu=new Student();
stu.setId(id);
stu.setName(name);
stu.setAge(age);
return studentResitory.save(stu);
}

8.删除

 /**
* 删除数据
*/
@DeleteMapping(value = "/hello/{id}")
public void deleteStu(@PathVariable("id") Integer id){
studentResitory.delete(id);
}

三:扩展

1.通过年龄还来查询

2.扩展接口

 package com.aspirant.springboot;

 import org.springframework.data.jpa.repository.JpaRepository;

 import java.util.List;

 public interface StudentResitory extends JpaRepository<Student,Integer> {

     //根据年龄来查询数据
public List<Student> findByAge(Integer age);
}

3.程序

 /**
* 根据年龄进行查询
*/
@GetMapping(value = "/hello/age/{age}")
public List<Student> getStuList(@PathVariable("age") Integer age){
return studentResitory.findByAge(age);
}

[转] Springboot的数据库操作的更多相关文章

  1. 【SpringBoot】数据库操作之整合Mybaties和事务讲解

    ========================8.数据库操作之整合Mybaties和事务讲解 ================================ 1.SpringBoot2.x持久化数 ...

  2. springBoot的数据库操作

    一:操作数据库起步 1.Spring-Data-Jpa JPA定义了对象持久化的标准. 目前实现了有Hibernate,TopLink 2.pom添加依赖 <dependency> < ...

  3. 利用IDEA构建springboot应用-数据库操作(Mysql)

    Spring-Date-Jpa 定义了一系列对象持久化的标准 例如Hibernate,TopLink等   spring data jpa让我们解脱了DAO层的操作,基本上所有CRUD都可以依赖于它来 ...

  4. springboot学习-springboot使用spring-data-jpa操作MySQL数据库

    我们在上一篇搭建了一个简单的springboot应用,这一篇将介绍使用spring-data-jpa操作数据库. 新建一个MySQL数据库,这里数据库名为springboot,建立user_info数 ...

  5. springboot学习-jdbc操作数据库--yml注意事项--controller接受参数以及参数校验--异常统一管理以及aop的使用---整合mybatis---swagger2构建api文档---jpa访问数据库及page进行分页---整合redis---定时任务

    springboot学习-jdbc操作数据库--yml注意事项--controller接受参数以及参数校验-- 异常统一管理以及aop的使用---整合mybatis---swagger2构建api文档 ...

  6. SpringBoot中使用spring-data-jpa 数据库操作(上)

    Java客户端使用Spring-Data-Jpa这个组件. Spring-Data-Jpa就是Spring对Hibernate的一个整合. 选择create在运行的时候它会自动帮我们创建一个表. sp ...

  7. Spring Boot快速入门(四):使用jpa进行数据库操作

    原文地址:https://lierabbit.cn/articles/5 添加依赖 新建项目选择web,JPA,MySQL三个依赖 对于已存在的项目可以在bulid.gradle加入,spring b ...

  8. 补习系列(16)-springboot mongodb 数据库应用技巧

    目录 一.关于 MongoDB 二.Spring-Data-Mongo 三.整合 MongoDB CRUD A. 引入框架 B. 数据库配置 C. 数据模型 D. 数据操作 E. 自定义操作 四.高级 ...

  9. SpringBoot02 Controller的使用、数据库操作、事物管理、修改banner

    1 Controller的使用 特点:编程技巧和SpringMVC几乎完全一样 注意:@RestController = @Controller + @ResponseBody 注意:读取路径参数和请 ...

随机推荐

  1. Vue的父子组件间通信及借助$emit和$on解除父子级通信的耦合度高的问题

    1.父子级间通信,父类找子类非常容易,直接在子组件上加一个ref,父组件直接通过this.$refs操作子组件的数据和方法    父 这边子组件中 就完成了父 => 子组件通信 2. 子 =&g ...

  2. jmeter进行简单性能测试

    本文使用jmeter做一个简单的压力测试. 压力测试的步骤:1.录制脚本或编写脚本:2.自定义参数:3.场景设计:4.使用控制器模拟用户:5.使用监听,查看测试结果 以10个用户登录http://ww ...

  3. Sping AOP Capabilities and Goals

    Spring AOP是用纯的java实现的.不需要任何个性的实现过程.Spring AOP不需要控制类加载器,并且它适用于Servlet容器或者应用服务器. Spring AOP当前只支持方法执行的连 ...

  4. WPF程序打包发布

    1.新建安装项目: 新建项目——其他项目类型——安装与部署——InstallShield Limited Edition Project 2.配置安装信息: 选择Project Assistant进入 ...

  5. hive -- 协同过滤sql语句

    hive -- 协同过滤sql语句 数据: *.3g.qq.com|腾讯应用宝|应用商店 *.91rb.com|91手机助手|应用商店 *.app.qq.com|腾讯应用宝|应用商店 *.haina. ...

  6. 此博客不再更新和分享UiPath文章

    由于版权问题,将不再分享我的笔记 警告:任何人不得拷贝及挪用我的uipath笔记作为商业用途,一旦发现,立刻发律师函,请知悉及慎重!!!!

  7. maven加载springboot project

    maven加载springboot project   1● 下载项目 2● 构建project mvn install mvn package   3● idea加载 4● run启动   ==== ...

  8. JSP之mysql中文乱码问题

    查看数据库编码方式 show variables like 'character%'; 关于jsp页面插入数据库乱码问题. 我遇到的问题是插入数据库后后台select * from tablename ...

  9. shell脚本学习之for循环

    1.数字循环 [root@zabbix ~]# for i in {1..10};do echo $(expr $i \* 3);done;36912151821242730 [root@zabbix ...

  10. eclipse里没有j2ee

    eclipse是客户端开发工具,本来就不带有j2ee的jar包,需要容器:比如tomcat来提供这个jar的.j2EE通用jar包列表:IKIKAnalyzer3.2.8.jar // 分词器ant- ...