[Spring] 회원 도메인과 리포지토리 만들기

Haeun Noh·2023년 8월 15일
1

TweeksStudy:1 (Spring)

목록 보기
8/13
post-thumbnail

0815


1. 회원 객체

package hello.hellospring.domain;

public class Member {

    private Long id;// 데이터를 구분하기 위해 시스템이 저장하는 아이디
    private String name;

    public Long getId() {
        return id;
    }
    public void setId(Long id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
}
  • id : 데이터를 구분하기 위해 시스템이 저장하는 아이디

2. 회원 리포지토리 인터페이스

package hello.hellospring.repository;

import hello.hellospring.domain.Member;

import java.util.List;
import java.util.Optional;

public interface MemberRepository {
    Member save(Member member);// 회원이 저장소에 저장됨
    Optional<Member> findById(Long id);// findBy.. : 저장소에서 알맞은 값 찾아옴
    Optional<Member> findByName(String name);
    List<Member> findAll();// 지금까지 저장된 모든 회원 리스트 반환
}
  • repository : 회원 객체를 저장하는 저장소
  • 인터페이스 기능
    • save() : 회원이 저장소에 저장됨
    • findById : 아이디로 회원 찾기
    • findByName : 회원이 가입할 때 입력한 이름으로 회원 찾기
    • Optional : findById가 null일 경우를 대비

3. 메모리 - 구현체

package hello.hellospring.repository;

import hello.hellospring.domain.Member;

import javax.swing.text.html.Option;
import java.util.*;

public class MemoryMemberRepository implements MemberRepository {

    private static Map<Long, Member> store = new HashMap<>();
    private static long sequence = 0L;// 실무에서는 동시성 문제를 위해 어텀롱을 사용함


    @Override
    public Member save(Member member) {
        member.setId(++sequence);
        store.put(member.getId(), member);
        return member;
    }

    @Override
    public Optional<Member> findById(Long id) {
        return Optional.ofNullable(store.get(id));// null이 포함될 가능성이 있다면 Optional 사용
    }

    @Override
    public Optional<Member> findByName(String name) {
        return store.values().stream()
                .filter(member -> member.getName().equals(name))
                .findAny();
    }

    @Override
    public List<Member> findAll() {
        return new ArrayList<>(store.values());
    }
}

(참고) 실무에서는 동시성 문제가 있을 수 있기 때문에 컨커런트 해시맵을 사용한다.

(참고) 무에서는 동시성 문제를 위해 어텀롱을 사용한다.

  • null이 포함될 가능성이 있다면 Optional 사용


profile
Tistory로 옮기게 되었습니다. @haeunnohh

0개의 댓글