강의/스프링부트 JPA활용 1

스프링부트 JPA활용 1 - 상품 도메인 개발(5)

KingBini 2022. 6. 10. 00:12

목차

  • 상폼엔티티 개발(비즈니스 로직 추가)
  • 상품 리포지토리 개발
  • 상품 서비스 개발구현기능
  • 상품 등록
  • 상품 목록 조회
  • 상품 수정

순서

  • 상품 엔티티 개발(비즈니스로직 추가)
  • 상품 리포지토리 개발
  • 상품 서비스 개발
  • 상품 기능 테스트 개발



📌상폼엔티티 개발(비즈니스 로직 추가)

상품 엔티티 코드

package jpabook.jpashop.domain.item;

import jpabook.jpashop.domain.Category;
import jpabook.jpashop.exception.NotEnoughStockException;
import lombok.Getter;
import lombok.Setter;

import javax.persistence.Entity;
import javax.persistence.*;
import java.util.ArrayList;
import java.util.List;

@Entity
@Inheritance(strategy = InheritanceType.SINGLE_TABLE)
@DiscriminatorColumn(name = "dtype")
@Getter @Setter
public abstract class Item {

    @Id @GeneratedValue
    @Column(name = "item_id")
    private Long id;

    private String name;

    private int price;

    private int stockQuantity;

    @ManyToMany(mappedBy = "items")
    private List<Category> categories = new ArrayList<>();


    //+비즈니스 로직//

    //stock 증가
    public void addStock(int quantity){
        this.stockQuantity += quantity;
    }

    //stock 감소
    public void removeStock(int quantity){
        int restStock = this.stockQuantity - quantity;
        if (restStock< 0){
            throw new NotEnoughStockException("need more stock");
        }
        this.stockQuantity = restStock;
    }

}

예외 추가

package jpabook.jpashop.exception;

public class NotEnoughStockException extends RuntimeException{
    public NotEnoughStockException() {
        super();
    }

    public NotEnoughStockException(String message) {
        super(message);
    }

    public NotEnoughStockException(String message, Throwable cause) {
        super(message, cause);
    }

    public NotEnoughStockException(Throwable cause) {
        super(cause);
    }


}

비즈니스 로직 분석

addStock()

  • 파라미터로 넘어온 수만큼 재고를 늘린다. 이 메서드는 재고가 증가하거나 상품 주문을 취소해서 재고를 다시 늘려야 할 때 사용한다.removeStock()
  • 파라미터로 넘어온 수만큼 재고를 줄이고, 만약 재고가 부족하면 예외가 발생한다. 주로 상품을 주문할 때 사용한다.



📌상품 리포지토리 개발

상품리포지토리

package jpabook.jpashop.repository;

import jpabook.jpashop.domain.item.Item;
import lombok.RequiredArgsConstructor;
import org.springframework.stereotype.Repository;

import javax.persistence.EntityManager;
import java.util.List;

@Repository
@RequiredArgsConstructor

public class ItemRepository {

    private final EntityManager em;

    //상품 저장
    public void save(Item item){
        if(item.getId() == null){
            em.persist(item);
        }else{
            em.merge(item);
        }
    }
    //상폼조회
    public Item findOne(Long id){
        return em.find(Item.class, id);
    }
    //상품 리스트 조회
    public List<Item> findAll(){
        return em.createQuery("select i from Item i",Item.class).getResultList();
    }

}

메서드 설명

save()

  • id가 없으면 신규로 보고 persist() 실행
  • id 가 있으면 이미 데이터메이스에 저장된 엔티티를 수정한다 보고, merge()를 실행한다.





📌상품 서비스 개발

상품 서비스 코드

package jpabook.jpashop.service;

import jpabook.jpashop.domain.item.Item;
import jpabook.jpashop.repository.ItemRepository;
import lombok.RequiredArgsConstructor;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;

import java.util.List;

@Service
@Transactional(readOnly = true)
@RequiredArgsConstructor
public class ItemService {

    private final ItemRepository itemRepository;
  /*  public ItemService(ItemRepository itemRepository){
        this.itemRepository = itemRepository;
    }*/// @RequiredArgsConstructor 로 생성자 자동생성

    @Transactional
    public void saveItem(Item item){
        itemRepository.save(item);
    }

    public List<Item> finItem(){
        return  itemRepository.findAll();
    }

    public Item findOne(Long itemId) {
        return  itemRepository.findOne(itemId);
    }
}





REF