일대일 [1:1]일대일 관계는 그 반대도 일대일이다.일대일 관계는 특이하게 주 테이블이나 대상 테이블 중에 외래 키를 넣을 테이블을 선택 가능하다.주 테이블에 외래 키 저장대상 테이블에 외래 키 저장외래 키에 데이터베이스 유니크 제약조건 추가되어야 일대일 관계가 된다.일대일 - 주 테이블에 외래 키 단방향회원이 딱 하나의 락커를 가지고 있는 상황이다. 반대로 락커도 회원 한명만 할당 받을 수 있는 비즈니스 적인 룰이 있고, 이때, 둘의 관계는 일대일 관계이다.이 경우 멤버를 주 테이블로 보고 주 테이블 또는 대상 테이블에 외래 키를 저장할 수 있다. 단, 유니크 제약조건을 추가한 상태에서만.다대일[N:1] 단방향 관계 매핑과 JPA 어노테이션만 달라지고, 거의 유사하다.일대일 - 주 테이블에 외래 키 양..
일대다 [1:N]일대다 관계에서는 일이 연관관계의 주인이다.일 쪽에서 외래키를 관리하겠다는 의미가 된다.결론을 먼저 말하자면, 표준스펙에서 지원은 하지만 실무에서 이 모델은 권장하지 않는다.일대다 단방향 매핑팀과 멤버가 일대다 관계이다.Team이 Members를 가지는데, Member 입장에서는 Team을 참조하지 않아도 된다라는 설계가 나올 수 있다. 객체 입장에서 생각하면 충분히 나올 수 있는 설계이다.그러나 DB 테이블 입장에서 보면, 무조건 일대다의 다쪽에 외래키가 들어간다.Team에서 members가 바뀌면, DB의 Member 테이블에 업데이트 쿼리가 나가는 상황이다.일대다 단방향 매핑JPA @OneToMany와 @JoinColumn()을 이용해서 일대다 단방향 매핑 코드로 이해하기Member..
다대일 [N:1]JPA에서 가장 많이 사용하고, 꼭 알야야 되는 다중성이다.아래 테이블에서 보면, DB 설계상 일대다에서 다 쪽에 외래키가 있어야 한다. 그렇지 않으면 잘못된 설계다.객체로 와서, 다대일 관계에서 다인 멤버에서 단순하게 팀으로 단방향 참조를 하고 싶다고 할 때, 테이블에 외래키 있는 쪽인 멤버 객체에서 팀객체로 연관관계 매핑 하면 된다.테이블에서 FK가 팀을 찾기 위해 존재하고, 객체에서 Team 필드도 Team을 참조하기 위해 존재한다.다대일의 반대는 일대다다대일 단방향 매핑JPA @ManyToOne 어노테이션을 사용해서 다대일 관계를 매핑한다.@JoinColumn은 외래 키를 매핑할 때 사용한다. name은 매핑할 외래 키 이름이다.public class Member { ... @Ma..
연관관계 매핑시 고려사항 3가지다중성JPA 에서는 다중성을 위한 어노테이션을 제공한다.이 JPA 어노테이션들은 DB와 매핑하기 위해 존재 한다.그래서 데이터베이스 관점에서의 다중성을 기준으로 고민 하면 된다.다대일 - @ManyToOne일대다 - @OneToMany일대일 - @OneToOne다대다 - @ManyToMany다중성을 고민하다가 풀리지 않으면 대칭성을 고려하자. 다중성의 관계들은 대칭성을 다 가지고 있다. 예를 들면, 회원과 팀 - 팀과 회원 둘다를 고려하면 쉬워 진다.단방향, 양방향이전 학습 내용 정리단방향 연관관계 - https://ict-nroo.tistory.com/121양방향 연관관계 - https://ict-nroo.tistory.com/122테이블은외래 키 하나로 양쪽을 조인할 수..
양방향 연관관계와 연관관계의 주인Team을 통해서도 getMemberList()로 특정 팀에 속한 멤버 리스트를 가져오고 싶다.객체 설계는 위와 같이 Member에서는 Team을 가지고 있고, Team에서는 Members를 가지고 있도록 설계하면 된다. DB를 보자. DB는 단방향 매핑때와 바뀌는게 없다. 왜냐. 둘을 join 하면 된다. DB는 방향이 없다!이 두가지가 큰 차이다.코드로 이해Member 엔티티는 단방향과 동일하다.@Entity public class Member { @Id @GeneratedValue private Long id; @Column(name = "USERNAME") private String name; private int age; @ManyToOne @JoinColum..
단방향 연관관계 매핑 이론객체지향 모델링객체 연관관계 사용해서 아래의 객체 참조와 테이블의 외래키를 매핑하는 방법 학습객체의 참조와 테이블의 외래 키를 매핑한다.외래 키 대신에 TEAM 객체를 넣고TEAM_ID를 매핑한다. @JoinColumn으로 조인 컬럼을 명시한다. 안적어도 default로 들어간다. 적어주는게 더 명시적이다.그리고 연관관계를 설정한다 @ManyToOne.하나의 Team이 여러개의 Member를 가지고 있다.그렇게 보면 TEAM 입장에서는 일대다,Member 입장에서는 다대일이다. @ManyToOne.이렇게 설정하면 Team 이라는 필드가 DB에 있는 TEAM_ID라는 FK와 매핑이 된다. 관계를 선언하고 조인할 컬럼을 매핑 했다.이것을 연관관계 매핑이라고 한다. ORM 매핑!!!!..
- Total
- Today
- Yesterday
- 젠킨스
- Spring Boot
- Algorithm
- 라즈베리파이
- JPA
- 순환
- 레드블랙트리
- springboot
- 한밭이글스
- vuex
- 정렬
- vuejs
- 한밭대학교
- 무선통신소프트웨어연구실
- ORM
- 알고리즘
- 스프링부트
- Java
- IT융합인력양성사업단
- RBT
- 시간복잡도
- github
- Recursion
- 자바
- Wisoft
- Spring
- Vue.js
- Raspberry Pi
- 인프런
- AWS
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | ||||
4 | 5 | 6 | 7 | 8 | 9 | 10 |
11 | 12 | 13 | 14 | 15 | 16 | 17 |
18 | 19 | 20 | 21 | 22 | 23 | 24 |
25 | 26 | 27 | 28 | 29 | 30 | 31 |