[인강노트 - querydsl] 3. 예제 도메인 만들기

봄도둑·2022년 12월 26일
0

김영한님의 실전! querydsl 강의 내용을 정리한 노트입니다. 블로그에 있는 자료를 사용하실 때에는 꼭 김영한님 강의 링크를 남겨주세요!

1. 엔티티 만들어주기

  • entity 코드
    @Entity
    @Getter
    @Setter
    @NoArgsConstructor(access = AccessLevel.PROTECTED) // JPA에서는 protected 레벨의 기본 생성자 필요
    @ToString(of = {"id", "username", "age"}) //연관 관계 필드는 toString 처리하면 무한루프탈 수 있음
    public class Member {
        @Id @GeneratedValue
        @Column(name = "member_id")
        private Long id;
        private String username;
        private int age;
    
        @ManyToOne(fetch = FetchType.LAZY)
        @JoinColumn(name = "team_id")
        private Team team;
    
        public Member(String username) {
            this(username, 0);
        }
    
        public Member(String username, int age) {
            this(username, age, null);
        }
    
        public Member(String username, int age, Team team) {
            this.username = username;
            this.age =age;
            if (team != null) {
                changeTeam(team);
            }
        }
    
        public void changeTeam(Team team) {
            this.team = team;
            team.getMembers().add(this);
        }
    }
    @Entity
    @Getter
    @Setter
    @NoArgsConstructor(access = AccessLevel.PROTECTED) // JPA에서는 protected 레벨의 기본 생성자 필요
    @ToString(of = {"id", "name"})
    public class Team {
    
        @Id @GeneratedValue
        private Long id;
        private String name;
    
        @OneToMany(mappedBy = "team")
        private List<Member> members = new ArrayList<>();
    
        public Team(String name) {
            this.name = name;
        }
    
    }

ctrl + shift + t 를 누르면 junit test를 만들 수 있음

ctrl + alt + v : 리턴 타입 자동 생성

iter : for문 자동 생성

테스트 코드

@SpringBootTest
@Transactional
@Commit //데이터가 들어갔는지 확인해보기 위해서 넣음
class MemberTest {
    @Autowired
    EntityManager em;

    @Test
    public void testEntity() {
       Team teamA = new Team("teamA");
       Team teamB = new Team("teamB");
       em.persist(teamA);
       em.persist(teamB);

       Member member1 = new Member("member1", 10, teamA);
       Member member2 = new Member("member2", 20, teamA);

       Member member3 = new Member("member3", 30, teamB);
       Member member4 = new Member("member4", 40, teamB);

       em.persist(member1);
       em.persist(member2);
       em.persist(member3);
       em.persist(member4);

       // 초기화
       em.flush();
       em.clear();

        List<Member> members = em.createQuery("select m from Member m", Member.class)
                .getResultList();

        for (Member member : members) {
            System.out.println("!!!!! member : " + member);
            System.out.println("!!!!! member.team : " + member.getTeam());
            //원래 테스트할 때는 sout으로 찍지말고 assertions로 검증하자
        }
    }
}
profile
Java Spring 백엔드 개발자입니다. java 외에도 다양하고 흥미로운 언어와 프레임워크를 학습하는 것을 좋아합니다.

0개의 댓글