package jpabook.jpashop.service;
import jpabook.jpashop.Member;
import jpabook.jpashop.repository.MemberRepository;
import lombok.AllArgsConstructor;
import lombok.RequiredArgsConstructor;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import java.util.List;
@Service
@RequiredArgsConstructor
public class MemberService {
// @Autowired
private final MemberRepository memberRepository; //final로 하는걸 권장
// @Autowired
// public MemberService(MemberRepository memberRepository) {
// this.memberRepository = memberRepository;
// 테스트케이스를 작성할 때 뭘 주입해야하는ㄴ지 잘 알 수 있다.
// }
//회원가입
@Transactional
public Long join(Member member) throws IllegalAccessException {
validateDuplicateMember(member); //중복 회원 검증
memberRepository.save(member);
return member.getId();
}
private void validateDuplicateMember(Member member) throws IllegalStateException {
//EXCEPTION
List<Member> findMembers = memberRepository.findByName(member.getName());
if (!findMembers.isEmpty()){
throw new IllegalStateException("이미 존재하는 회원입니다.");
}
}
//회원 전체 조회(조회같은 읽기전용에서 readOnly는 트루한다.)
@Transactional(readOnly = true)
public List<Member> findMembers(){
return memberRepository.findAll();
}
@Transactional(readOnly = true)
public Member findOne(Long memberId){
return memberRepository.findOne(memberId);
}
}
@Autowired : 생성자 Injection에 많이 사용한다. 생성자가 하나면 생략이 가능하다.
@Transactional : 트랜잭션, 영속성 컨텍스트
JPA에서 모든 데이터 변경과 로직들은 트랙잭션 안에서 실행되어야한다.
readOnly=true : 읽기 전용 메서드에 사용이 된다. 영속성 컨텍스트를 플러시 하지 않아서 약간의 성능 향상이 된다.
회원명 컬럼에 유니크 제약 조건을 걸어 멀티 쓰레드 상황에 대비해야 한다.
필드 주입 vs 생성자 주입
Lombok
@AllargsConstructor
생성자를 대신 만들어 준다.
@RequiredArgsConstructor
final이 붙여진 코드에만 생성자를 만들어준다.
'백엔드 > 실전! 스프링 부트와 JPA 활용1 - 웹 애플리케이션 개발' 카테고리의 다른 글
실전! 스프링 부트와 JPA 활용1 - 상품, 주문 도메인 개발 (0) | 2023.01.18 |
---|---|
실전! 스프링 부트와 JPA 활용1 - 웹 계층 개발 (0) | 2023.01.08 |
실전! 스프링 부트와 JPA 활용1 - 도메인 분석 설계 (0) | 2022.12.27 |