SpringBoot自学好几天 中途开始写笔记 SpringBoot数据访问 Spring JPA 20190222

一、 Spring Data

1. SpringData特点
SpringData 为我们提供使用统一的API来对数据访问层进行操作;这主要是Spring Data Commons 项目来实现 SpringData Commons让我们在使用关系型数据库或者非关系型数据库访问技术时都基于Spring提供的统一标准,标准包含了CRUD(创建、获取、更新、删除)、查询、排序和分页的相关操作
2. SpringData 统一的Repository
SpringBoot自学好几天 中途开始写笔记 SpringBoot数据访问 Spring JPA 20190222_第1张图片
3. SpringData 提供数据访问模板类xxxTememplate
例如:MongoTemplete RedisTemplete 等
4. JPA与Spring Data
SpringBoot自学好几天 中途开始写笔记 SpringBoot数据访问 Spring JPA 20190222_第2张图片
有了Spring Data 我们就面向Soring Data编程了
SpringBoot自学好几天 中途开始写笔记 SpringBoot数据访问 Spring JPA 20190222_第3张图片
Spring JPA 是关系型数据库java持久化API
https://download.csdn.net/download/qq_36291682/10969562

二、整合JPA 操作数据库

  1. 创建项目
    SpringBoot自学好几天 中途开始写笔记 SpringBoot数据访问 Spring JPA 20190222_第4张图片
    SpringBoot自学好几天 中途开始写笔记 SpringBoot数据访问 Spring JPA 20190222_第5张图片
    SpringBoot自学好几天 中途开始写笔记 SpringBoot数据访问 Spring JPA 20190222_第6张图片
    SpringBoot自学好几天 中途开始写笔记 SpringBoot数据访问 Spring JPA 20190222_第7张图片
  2. pom.xml
<dependency>
            <groupId>org.springframework.bootgroupId>
            <artifactId>spring-boot-starter-data-jpaartifactId>
        dependency>
        <dependency>
            <groupId>org.springframework.bootgroupId>
            <artifactId>spring-boot-starter-jdbcartifactId>
        dependency>
        <dependency>
            <groupId>org.springframework.bootgroupId>
            <artifactId>spring-boot-starter-webartifactId>
        dependency>

        <dependency>
            <groupId>mysqlgroupId>
            <artifactId>mysql-connector-javaartifactId>
            <scope>runtimescope>
        dependency>
        <dependency>
            <groupId>org.springframework.bootgroupId>
            <artifactId>spring-boot-starter-testartifactId>
            <scope>testscope>
        dependency>

依赖关系,我们可以知道jpa底层用的是hibernate
SpringBoot自学好几天 中途开始写笔记 SpringBoot数据访问 Spring JPA 20190222_第8张图片

  1. 新建数据库
    SpringBoot自学好几天 中途开始写笔记 SpringBoot数据访问 Spring JPA 20190222_第9张图片
  2. 配置数据源 application.yml 配置数据源 application.yml
spring:
  datasource:
    url: jdbc:mysql://127.0.0.1:3306/jpa?useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTC
    username: root
    password: 123456
    driver-class-name: com.mysql.cj.jdbc.Driver
  1. JPA是ORM(Object Relational Mapping ) 所以我们需要编写一个实体类(bean),实体类和数据表进行映射 并用JPA注解 将它标注
package com.example.springboot.entity;

import javax.persistence.*;

/**
 * @author LM
 * @create 2019-02-22 21:15
 */
//配置映射关系
@Entity //告诉jpa这是一个实体类 和 数据表映射的类
@Table(name = "tbl_user") //指定和哪个数据表对应  如果省略 表名就是类名小写
public class User {

    @Id //这是一个主键
    @GeneratedValue(strategy = GenerationType.IDENTITY) //自增主键
    private Integer id;

    @Column(name="last_name",length = 50) //与数据表对应的列
    private String lastName;

    @Column //省略 默认列名就是属性名  
    private String email;

    public Integer getId() {
        return id;
    }

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

    public String getLastName() {
        return lastName;
    }

    public void setLastName(String lastName) {
        this.lastName = lastName;
    }

    public String getEmail() {
        return email;
    }

    public void setEmail(String email) {
        this.email = email;
    }
}

  1. 编写dao操作实体类对应数据表(Repository)
package com.example.springboot.repository;

import com.example.springboot.entity.User;
import org.springframework.data.jpa.repository.JpaRepository;

/**
 * @author LM
 * @create 2019-02-22 21:23
 * 继承JpaRepository完成对数据库的操作  User是对应哪个实体类 Integer是主键的类型
 */
public interface UserRepository extends JpaRepository<User,Integer> {
}

  1. 配置JPA application.yml 所有jpa相关配置都在JpaProperties.class中
 jpa:
    hibernate:
    #更新或创建数据表  会根据实体类自动创建表 如果表发生变化 也会自动创建
      ddl-auto: update
    #控制台显示sql
    show-sql: true
    database-platform: org.hibernate.dialect.MySQL5Dialect

  1. 启动
    启动之前还没有表呢
    SpringBoot自学好几天 中途开始写笔记 SpringBoot数据访问 Spring JPA 20190222_第10张图片
    启动完之后:
    SpringBoot自学好几天 中途开始写笔记 SpringBoot数据访问 Spring JPA 20190222_第11张图片

  2. 新建controller测试

package com.example.springboot.controller;

import com.example.springboot.entity.User;
import com.example.springboot.repository.UserRepository;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RestController;

import java.util.Optional;

/**
 * @author LM
 * @create 2019-02-22 21:51
 */
@RestController
public class UserController {

    @Autowired
    UserRepository userRepository;

    @GetMapping("/user/{id}")
    public User getUser(@PathVariable("id") Integer id){
        Optional<User> user =  userRepository.findById(id);
        return  user.get();
    }

    //为了测试方便 这里新增应该用post
    @GetMapping("/user/save")
    public User insertUser(User user){
      //自增主键会设置到u中
      User u =   userRepository.save(user);
      return u;
    }
}

保存:
SpringBoot自学好几天 中途开始写笔记 SpringBoot数据访问 Spring JPA 20190222_第12张图片
查询:
SpringBoot自学好几天 中途开始写笔记 SpringBoot数据访问 Spring JPA 20190222_第13张图片

你可能感兴趣的:(SpringBoot)