김데이의 개발공부

[ Weekly Paper 06 ] 관계형 데이터베이스 / Primary Key & foreign Key 본문

코드잇 Node.js(BE) 부트 캠프/위클리 페이퍼 📃🖌️

[ Weekly Paper 06 ] 관계형 데이터베이스 / Primary Key & foreign Key

theday365 2025. 12. 5. 16:33
반응형

 

(오랜만에 돌아온 위클리페이퍼 😉

실습 하는 동안에는 위클리 페이퍼가 없었어요~! )

 

 

위클리 페이퍼 주제 (2025.11.24 ~ 11.28, 늦게 올림 12.05)

✅ 웹 서비스에서 관계형 데이터베이스를 사용하는 이유 중 하나를 설명 해 주세요

✅ Primary Key와 Foreign Key에 대해 설명해 주세요

 


 

친철한 IBM 관계형 데이터베이스 설명 : https://www.ibm.com/kr-ko/think/topics/relational-databases

 

관계형 데이터베이스란 무엇인가요? | IBM

이 필수 가이드에서는 관계형 데이터베이스의 작동 방식과 다른 데이터베이스 옵션과 비교하는 방법에 대해 알아봅니다.

www.ibm.com

 

Q1 - 1. 관계형 데이터베이스란?

  • 데이터를 행과 열로 구성하는 데이터 베이스 유형
  • 스키마(정해진 구조)가 명황해서 데이터가 일관되고 안정적
  • 기본키나 외래키를 통해 다른 테이블과 관계(조인)될 수 있음(여러 테이블에 걸쳐 구성 가능) 
  • 복잡한 조회가 필요할 때 아주 강력함
  • SQL(Structured Query Language) 언어 사용 

 

Q1 - 2. 비 관계형 데이터베이스란?

  • 비정형 데이터나 빠르게 변하는 구조에 적용하기 좋음
  • 스키마가 자유로워서 데이터 입력/수정이 자유로움
  • 관계(조인)이 없고, 대신 한 문서 안에 관련 데이터를 몽땅 넣는 방식
  • 서로 독립적인 구조를 가지고 있어서 확장성이 좋음

 

Q1 - Final . 웹 서비스에서 관계형 데이터베이스를 사용하는 이유 중 하나를 설명 해 주세요 

  1. 다루는 정보에 민감한 정보가 많으므로 데이터의 정확성(무결성)이 굉장히 중요함
    : 유저 정보, 주문 정보, 결제 정보처럼 높은 정확도를 필요로 하는 서비스에서는 필수로 저장 해야 할 정보들이 많고,
      각 정보가 연계되어 있기 때문에 비형식적이고 관계성이 낮게 저장 된 비 관계형 데이터로 서비스 하기엔 무리가 있음 

  2. 웹 서비스가 고도화 되면서 복잡한 서비스가 많아짐 
    : 대부분의 웹 서비스가 한가지의 기능 제공으로 서비스가 끝나지 않음,
      서로 연계된 작업을 위해서는 관계형 데이터베이스가 필요
      ex) "로그인" 한 유저 만 "게시글을 쓸"수 있으며, 다른 사람의 글에 "댓글"도 작성 가능 

 


Q2 - 1.  관계형 데이터베이스의 구조

주요 구성 요소

  • 개체, Entity : 저장해야 할 대상 
  • 속성, Attribute : 개체의 세부 정보, 속성 => 컬럼에 맵핑 되는 정보
  • 관계, Relationship : 여러 Entity들 간의 관계, 즉 각각의 Entity Model( = 실제 DB의 table) 사이의 관계

 

Q2 - Final . Primary Key와 Foreign Key에 대해 설명해 주세요 

Primary Key 의 특징 

  • 고유 식별자, 즉 레코드를 구별할 수 있는 유일한 값
  • null이 허용되지 않음
  • 같은 테이블 안에서 중복된 값 사용 불가
  • 다른 테이블과 관계를 맺을 수 있는 FK의 기준

 

Foreign Key의 특징

  • 테이블 간의 논리적 관계를 설정하는 데 사용하는 키 
  • 참조 테이블의 관계키가 삭제되거나 변경되는 경우, 현재 테이블에서의 수행 동작을 설정 가능

 

user의 데이터 그래프
user의 데이터 그래프


 

다음 주에 또 만나요 🖐️

반응형