OneToOne 관계
319
작성한 질문수 3
USER와 Profile테이블은 OneToOne 관계입니다.
근데 서로 하나씩만 존재하다면 그냥 USER테이블에 Profile을 넣어버리면 되는거 아닌가요?
OneToOne 관계를 유지하는 특별한 이유가 있나요??
하나의 테이블이 커지는걸 방지하기 위해 OneToOne 관계를 형성하는 걸까요?
답변 1
1
안녕하세요, 인프런 AI 인턴이에요.
OneToOne 관계는 두 엔티티 간에 하나의 행만 매핑이 가능한 관계입니다. 여기서 Profile 테이블이 User와 OneToOne 관계를 가지면, Profile 당 한개의 User 행만을 갖습니다. 이 관계를 유지하는 특별한 이유는 각각의 엔티티가 서로 다른 개념이기 때문에 분리를 유지해야 할 경우가 많기 때문입니다.
그리고, User 테이블에 Profile을 포함시켜버린다면, Profile 테이블이 필요하지 않기 때문에 더 이상 프로필 정보를 담을 테이블이 없어지게 됩니다. 하지만, 만약에 사용자가 여러 개의 프로필을 가지거나 Profile 정보에 하위 테이블이 더 존재한다면, User 테이블에 Profile을 넣음으로써 테이블이 더 복잡해지게 됩니다. 그러므로, OneToOne 관계를 유지함으로써 각각의 엔티티를 분리하여 보다 명확한 데이터 구조를 유지할 수 있습니다.
따라서, OneToOne 관계는 테이블의 크기를 줄이는 것이 아니라 분리를 유지하여 데이터 구조의 명확성을 유지하기 위해 사용됩니다.
참고하시길 바랍니다. 감사합니다.
프로젝트 환경 세팅할 때 최신 노드 버젼을 사용하시는 분들은 참고하셔도 좋을 것 같아요~
2
83
1
DTO에 대한 질문
1
88
2
백엔드 MVC에서 View의 역할은 무엇인가요?
1
95
2
추가 업데이트 관련 건
0
92
2
nest js 버전문제
0
81
2
mongdb 스키마 공식 문서와 형태가 다른 이유 궁금합니다.
0
103
1
라인 끝에 에러 표시(eslint) 때문에 구글 찾아 보니.
0
77
1
전체 고양이 조회 라우터 중 error.message 오류
0
70
1
캡슐화 추가 설명 중 단일책임원칙 관련 질문
0
106
0
TypeORM과 mysql을 사용하시는 분들
4
143
1
42강 고양이끼리 소통 댓글 구현 중 Schema hasn't been registered for model 'comments' 에러 해결
0
82
1
채팅 이슈
0
134
1
모듈이 더 이상 지원하지 않는답니다
0
207
1
오류가 있습니다
0
107
1
import 에서 오류가 납니다
0
128
1
이런 오류가 나옵니다
0
101
1
에러가 발생합니다
0
111
1
프론트 에러 뜨는데 수정 안해주시나요
0
159
1
emit() broadcast.emit() 질문있습니다
0
103
1
서버연결이 안됩니다.
1
403
1
[PM2][ERROR] Command not found
0
521
1
S3에 업로드까지는 성공했는데 사진이 나오지 않습니다.
0
248
1
error_code : Property 'user' does not exist on type 'Request<ParamsDictionary, any, any, ParsedQs, Record<string, any>>'.ts(2339)
0
603
1
jwt를 따로 연습하고 있는데 env를 못읽는 것 같습니다.
0
324
2





