상품 엔티티 개발(비즈니스 로직 추가)
@Entity
@Inheritance(strategy = InheritanceType.SINGLE_TABLE)
@DiscriminatorColumn(name = "dtype")
@Getter @Setter
public 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<>();
//==비즈니스 로직==// 엔티티 자체가 해결할 수 있는 것은 엔티티 안에 비즈니스 로직을 넣는게 좋음
//@Setter가 아니라 이렇게 비즈니스 로직으로 변경해야함.
/**
* 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;
}
}
- @Setter가 아니라 비즈니스 로직을 이용하여 stock을 control해야함.
- 엔티티 자체가 해결할 수 있는 것은 엔티티 안에 비즈니스 로직을 넣는게 좋다.
- 해당 도메인만 사용하는 비즈니스 로직이면 도메인 내에 작성
- 여러 도메인이 사용하는 비즈니스 로직이면 서비스 계층에 작성
상품 리포지토리 개발
@Repository
@RequiredArgsConstructor
public class ItemRepository {
private final EntityManager em;
public void save(Item item) {
if(item.getId() == null) { //처음엔 id가 없는 것은 새로 생성한 객체. 그래서 persist로 저장
em.persist(item);
} else {
em.merge(item); //update와 비슷함
}
}
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();
}
}
- id가 없으면 완전히 새로운 객체로 보고 persist()를 호출해서 id를 만들어서 저장다.
- id가 있으면 이미 데이터베이스에 저장된 엔티티를 수정한다고 보고, merge()를 호출한다. 업데이트하는 것과 비슷하다.
상품 서비스 개발
@Service
@Transactional(readOnly = true)
@RequiredArgsConstructor
public class ItemService {
private final ItemRepository itemRepository;
@Transactional
public void saveItem(Item item) {
itemRepository.save(item);
}
public List<Item> findItems() {
return itemRepository.findAll();
}
public Item findOne(Long itemId) {
return itemRepository.findOne(itemId);
}
}
- ItemService는 단순하게 ItemRepository에 위임만 하는 동작을 수행한다.
728x90
'Spring' 카테고리의 다른 글
[Springboot & JPA 1] 웹 계층 개발 (2) | 2024.05.15 |
---|---|
[Springboot & JPA 1] 주문 도메인 개발 (0) | 2024.05.04 |
[Spring boot & JPA 1] 회원 도메인 개발 (0) | 2024.05.01 |
[Spring boot& JPA 1] 도메인 분석 설계 (3) | 2024.04.28 |
[Spring DB2] 스프링 트랜잭션 전파2 - 활용 (0) | 2024.03.31 |