봄 부팅 + JPA + Mysql-의 간단한 쿼리 - CRUD

 

자바 웹 개발은 일반적으로 (컨트롤러는 요청 반환 응답, 제어 데이터를 받아) 웹 층을 포함, 레이어 서비스 (비즈니스 로직), 데이터베이스 작업 층.

JavaWeb 고전적인 3 계층 프레임 워크는
    우리는 종종 JavaWeb에 의해 제안 된 3 계층 프레임 워크, 그게 JavaWeb 고유 한 말을하는 것입니다 말!
    소위 3 계층은 프리젠 테이션 계층 (WEB 층), 비즈니스 로직 (비즈니스 로직) 및 데이터 액세스 계층 (데이터 액세스)입니다.
        * WEB 층 : 서블릿 JSP를 포함하고, 웹 콘텐츠에 관련된 같은;
        * 비즈니스 계층 : 비즈니스 계층은 만 비즈니스 로직과 관련되어, JavaWeb의 API를 포함하지 않습니다
        * 데이터 층 : 만든 트랜잭션 층의 세부 사항의 데이터베이스에 패키지 액세스 추가 데이터, 삭제, 수정, 업데이트에 대한 데이터베이스를 직접 운영, 검색 및 기타.
    웹 서비스 계층에 의존 계층, 비즈니스 계층 종속 데이터 계층, 데이터 계층 운전 데이터!
    참고 :
        등 서비스 계층에서 JavaWeb의 API, 예를 들어, 요청, 응답 및 표시되지. 즉, 비즈니스 계층 코드는 재사용
    도 아닌 웹 환경에 적용 할 수 있습니다. 각 서비스 층의 전사 방법은, 상법, 예컨대, 보편적으로 이해 될 수있다.

참고 :

어셈블리 (예를 들어, 액션 스트럿) 주석 층을 제어하는 ​​컨트롤러 @ 비즈니스 계층의 구성 요소에 대한 @Service 라벨 @ 리포지토리 주석 데이터 액세스 컴포넌트, 즉 DAO 부품 및 조립체 좋은 복귀되지 않을 때, 조립체 @Component를 지칭 클래스는, 우리는 표시로이 주석을 사용할 수 있습니다.  

1. 전체 엔티티 객체 (도서) 구성

package com.lrm.domain;

import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.stereotype.Component;

import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;


@Entity
public class Book {


    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    private long id;

    private String name;

    private String author;

    private int status;

    private String description;

    public Book() {
    }

    public String getName() {
        return name;
    }

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

    public String getAuthor() {
        return author;
    }

    public void setAuthor(String author) {
        this.author = author;
    }

    public long getId() {
        return id;
    }

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

    public int getStatus() {
        return status;
    }

    public void setStatus(int status) {
        this.status = status;
    }

    public String getDescription() {
        return description;
    }

    public void setDescription(String description) {
        this.description = description;
    }
}

 

구성 데이터 영역의 2 동작

인터페이스를 생성 JpaRepository 상속 인터페이스는 데이터 조작 JPA 후에 제공 될 수있다

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


public interface BookRepository extends JpaRepository<Book,Long> {
}

3. 고정 비즈니스 계층 (서비스)

为了让controller可以注入BookService使用注解@Service

import com.lrm.domain.Book;
import com.lrm.domain.BookRepository;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import java.util.List;


@Service
public class BookService {

    @Autowired
    //@Autowired 注释,它可以对类成员变量、方法及构造函数进行标注,
    // 完成自动装配的工作。
    // 通过 @Autowired的使用来消除 set ,get方法。
    private BookRepository bookRepository;


    /**
     * 查询所有的书单列表
     * @return
     */
    public List<Book> findAll() {
        return bookRepository.findAll();
    }

    /**
     * 提交一个书单信息
     * @param book
     * @return
     */
    public Book save(Book book) {
        return bookRepository.save(book);
    }

    /**
     * 获取一条书单信息
     * @param id
     * @return
     */
    public Book findOne(Long id) {
        //return bookRepository.findOne(id);//2.0.0.以上版本
        return bookRepository.findById(id).get();//2.0.0.以下版本
    }
    /**
     * 删除一条书单信息
     * @param id
     */
    public void delete(long id) {
        bookRepository.deleteById(id) ;//2.0.0.以上版本
        //   bookRepository.delete(id);//2.0.0.以下版本
    }
}

4.web层(controller,控制数据的接受请求和返回响应)

读取数据

添加数据

更新数据

以下两种方法都可以:

方法一:

    /**
     * 更新一个书单
     * @param id
     * @param name
     * @param author
     * @param description
     * @param status
     * @return
     */
    @PutMapping("/books")
    public Book update(@RequestParam long id,
                       @RequestParam String name,
                       @RequestParam String author,
                       @RequestParam String description,
                       @RequestParam int status) {
        Book book = new Book();
        book.setId(id);
        book.setName(name);
        book.setAuthor(author);
        book.setDescription(description);
        book.setStatus(status);

        return bookService.save(book);
    }

方法二:

    /**
     * 更新一个书单
     * @param id
     * @param name
     * @param author
     * @param description
     * @param status
     * @return
     */


    @PutMapping("/books")
    public Book update(Book book) {

        return bookService.save(book);
    }

删除数据

    /**
     * 删除一个书单
     * @param id
     */
    @DeleteMapping("/books/{id}")
    public void deleteOne(@PathVariable long id) {

        bookService.delete(id);
    }

源码链接:

链接:https://pan.baidu.com/s/15O5ZefBWxP-RWyZwtOXtmA 
提取码:pbt4

发布了153 篇原创文章 · 获赞 6 · 访问量 2361

추천

출처blog.csdn.net/yangshengwei230612/article/details/103732393