todos 테이블, RLS, 트리거 생성 미션 질문드립니다
97
작성한 질문수 1
정답으로 보여주신 이미지에는 아래와 같이 FK가 설정되어있는 것 같았는데 맞을까요?
profiles.user_id -> auth.users.id (CASCADE) todos.user_id -> auth.users.id (CASCADE) todos.user_id -> profiles.users.id (CASCADE)
todos.user_id -> profiles.users.id를 잇는 FK는 왜 필요한거고, 어떤 의도로 생성하는것인지 궁금합니다
답변 2
0
안녕하세요, 인프런 AI 인턴입니다. 춘녕녕님.
제시된 관계에서 todos.user_id -> profiles.users.id (CASCADE)로 연결된 외래 키(Foreign Key)는 데이터베이스의 무결성(integrity)을 유지하기 위한 것입니다. 데이터의 consistency를 보장하고 데이터베이스의 구조적 관계를 명확히 하기 위해 외래 키 설정은 중요합니다.
FK의 목적: 외래 키는
todos테이블의user_id가profiles테이블의user_id와 일치해야 함을 보장합니다. 이렇게 함으로써todos테이블에 있는 항목들이 이미 존재하는 사용자 프로필에 연결되도록 보장합니다.의도와 효과:
- 데이터 무결성을 유지하여 잘못된 데이터 삽입을 방지합니다.
- 데이터베이스 관계를 명확히 정의하고, 데이터를 조작할 때 이를 통해 참조 무결성을 자동으로 관리합니다.
- CASCADE 옵션은 상위 테이블에서 데이터를 삭제하거나 수정할 때, 참조된 하위 테이블의 데이터가 자동으로 삭제되거나 수정되도록 설정합니다.
- 데이터 무결성을 유지하여 잘못된 데이터 삽입을 방지합니다.
이와 관련된 더 깊은 이해는 아래 URL에서 접근하여 기존의 답변들을 참고해보시면 도움이 될 수 있습니다:
- 시퀄라이즈 as 역할 - 시퀄라이즈 모델에서 외래 키와 관계 설정에 대한 논의입니다.
- 질문이 계속생기네요… - 외래 키와 테이블 관계 설정에 대한 구체적인 예시를 제공하는 답변입니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
구매후 바로 질문 하나만요..
0
16
1
MySql
0
8
1
회원가입 구현 (구현 후 최종 화면 출력 X)
0
14
2
팬텀리드 해결 예시 질문
0
13
0
최신버젼 다운로드
0
20
2
형 이번에 낸 책이랑 강의 내용에 차이가 있어?
1
36
1
형 나 몰래 책내면 모를 줄 알고?
1
29
1
차단 등 검증 로직의 위치
0
30
2
ai가 만든 강의인가요?
0
46
1
VSCode 설정 문의
0
33
2
(6.11) 회원가입시 프로필 정보 자동 생성하기 Q. 호출 순서 문의
0
26
1
강의 중복 확인 요청
0
26
1
캐시전략 - Write-behind
0
34
2
일대일 fk 위치
0
30
1
수업에서 사용하는 툴 질문드려요
0
38
2
중복내용 제보?!
1
48
2
다음 강의는 언제쯤 나올까요?
0
50
2
궁금한점이 여러개 생겼습니다.
1
47
1
강의자료 문의
0
20
1
제 3 정규형 vs BCNF 정규형 차이점?
0
44
3
수파베이스 ORM 질문
0
33
2
트리거 질문
0
32
1
비개발자이고, 바이브코딩을 하는 40대중반 직장인입니다.
0
180
1
감사히 잘 듣겠습니다.
1
106
1





