package jpabook.jpashop.domain.item;
import jpabook.jpashop.domain.Category;
import jpabook.jpashop.exception.NotEnoughStockException;
import lombok.Getter;
import lombok.Setter;
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;
}
}
2가지 비즈니스 로직을 넣을 것입니다.
stockQuantity
라는 재고 수량이 Item 엔티티 안에 있습니다. 그러면 이 데이터를 가지고 있는 곳에서 비즈니스 로직이 나가는 것이 가장 응집도가 있습니다.NotEnoughStockException
예외는 만들 것입니다.보통 개발을 할 때 Item Service에서 stockQuantity를 가져와서 거기서 stock을 더하거나 빼서 값을 만들고 마지막에 Item.setstockQuantity()해서 결과를 넣는 식으로 많이 코드를 작성했을겁니다.