JPA

一、JPA简介
1、JPA
JPA(Java Persistence API)是Sun官方提出的Java持久化规范。
它的出现主要是为了简化现有的持久层化开发工作,Hibernate就是一个很典型的JAP的实现。

JPA规范和持久层框架之间的关系
在这里插入图片描述
2、Spring Data JPA
在这里插入图片描述
这张图和上一张图的区别
Spring data spa 是在JPA规范下提供了持久层的实现(也就是我们常说的dao层),
虽然ORM框架都实现了JPA的规范,但是在不同的ORM框架之间切换需要编写不同的代码,
而通过使用Spring data jpa 可以不需要掌握持久层的框架的太多技术。
并且Spring data jpa 对持久层的封装很好,几乎不用编写代码,或编写很少的代码就能实现数据访问,使用起来很方便。

1、依赖

<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
</dependency>

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

2、配置

#mysql配置
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.username=root
spring.datasource.password=123456
spring.datasource.url=jdbc:mysql://localhost:3306/springboot-book?useUnicode=true&characterEncoding=UTF-8

#JPA配置
spring.jpa.show-sql=true
spring.jpa.hibernate.ddl-auto=update

3、创建数据库
springboot-book
4、定义持久化对象

@Entity
public class Book {

    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)//自动选择一个最适合底层数据库的主键生成策略
    private Long bookId;

也可以自定义表名和列名

@Entity(name="t_book")
public class Book {

    @Id
    @Column(name="id")
    @GeneratedValue(strategy = GenerationType.AUTO)//自动选择一个最适合底层数据库的主键生成策略
    private Long bookId;

    @Column(name="name")
    private String bookName;

5、重启程序
发现数据库表和列自动创建
6、执行sql脚本插入测试数据
见资源目录中的文件

三、架构和列表展示
1、创建dao层(数据访问层)
只需继承接口即可,无需编写任何代码

import org.springframework.data.jpa.repository.JpaRepository;
/**
 * 继承jpa的 JpaRepository,默认集成CRUD的基本功能
 */
public interface BookRepository extends JpaRepository<Book, Long>{
}

2、创建service 接口(业务层)

import java.util.List;
public interface BookService {

    List<Book> getBookList();
}

3、创建service 实现

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import java.util.List;

@Service//通过Spring管理对象的创建
public class BookServiceImpl implements BookService {

    @Autowired//通过Spring管理对象的依赖
    private BookRepository bookRepository;

    /**
     * 查询所有图书信息
     * @return 图书列表
     */
    @Override
    public List<Book> getBookList() {
        return bookRepository.findAll();
    }
}

4、创建controller2

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;

import java.util.List;

@RestController
@RequestMapping("api2")
public class BookController2 {

    @Autowired
    private BookService bookService;

    @GetMapping("books")
    public List<Book> getBookList(){
       return bookService.getBookList();
    }
}

四、完善应用程序
1、业务层其他
接口

Book getBookById(Long id);

Book saveBook(Book book);

Book updateBookById(Long id, Book book);

void deleteBookById(Long id);

实现

@Override
public Book getBookById(Long id){
    //注意此处是findOne,而不是getOne
    Book book = bookRepository.findOne(id);
    return book;
}
@Override
public Book saveBook(Book book) {
    //没有id是保存
    return bookRepository.save(book);
}

@Override
public Book updateBookById(Long id, Book book) {
    //有id是更新
    book.setBookId(id);
    return bookRepository.save(book);
}
@Override
public void deleteBookById(Long id) {
    bookRepository.delete(id);
}

2、web层其他

@GetMapping("books/{id}")
public Book getBookById(@PathVariable("id") Long id){
    return bookService.getBookById(id);
}

@PostMapping("books")
public Book saveBook(@RequestBody Book book){
    return bookService.saveBook(book);
}

@PutMapping("books/{id}")
public Book updateBookById(@PathVariable("id") Long id, @RequestBody Book book){
    return bookService.updateBookById(id, book);
}

@DeleteMapping("books/{id}")
public String deleteBookById(@PathVariable("id") Long id){
    bookService.deleteBookById(id);
    return "success";
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值