[Oracle] 데이터 무결성 제약 조건의 종류 [primary key, unique key, foreign key, NOT NULL, CHECK]

2023. 10. 25. 19:12·▣ SQL : Database/Oracle SQL🏮
728x90


- 데이터 무결성 제약 조건의 종류

무결성 제약 조건 설명
NOT NULL 열이 NULL을 포함할 수 없음
고유 키(unique key) 테이블의 모든 행에서 고유한 값을 갖는 열 또는 열 조합을 지정
기본 키(primary key) 해당 컬럼 값은 반드시 존재해야 하며 유일해야 함
(UNIQUE, NOT NULL 제약조건을 결합한 형태)
참조 키(foreign key) 한 열과 참조된 테이블의 열 간에 외래 키 관계를 설정하고 시행
CHECK 해당 칼럼에 저장 가능한 데이터 값의 범위나 조건 지정

데이터 무결성 제약 조건의 종류


1. NOT NULL 무결성 제약 조건

  • 해당 컬럼의 값이 NULL을 가질 수 없다는 것을 정의하는 제약 조건
  • 테이블 레벨이 아닌 열 레벨로만 지정 가능하다.
  • NOT NULL 무결성 제약조건이 지정된 칼럼은 반드시 값을 입력해야 한다. (생략 시 오류 발생)
  • 기존 데이터를 NULL로 수정하는 경우에도 오류 발생

NOT NULL 무결성 제약조건


2. 고유 키 무결성 제약 조건

  • 한 테이블 내에서 칼럼이 동일한 값을 가질 수 없음을 정의하는 제약 조건
  • 열 레벨 또는 테이블 레벨로 정의할 수 있다.
  • NULL은 고유 키 제약 조건에 위배되지 않으므로 입력할 수 있다. (NULL은 항상 UNIQUE 함)
  • 고유 키 무결성 제약 조건이 정의되면 테이블에 제약 조건과 같은 이름의 인덱스가 자동적으로 생성

고유키 무결성 제약조건


3. 기본 키 무결성 제약 조건

  • 기본 키는 테이블 내에 저장된 행을 유일하게 식별할 수 있는 식별자로 사용
  • 하나 이상의 컬럼에 의해 테이블의 모든 행을 구별하기 위한 식별자를 정의하기 위한 제약 조건
  • 관계형 데이터 모델에서 테이블은 행을 원소로 가지는 집합으로 정의되어 집합 내의 모든 행을 구별할 수 있는 식별자가 필요
  • 고유 키 제약 조건과 NOT NULL 제약 조건을 결합한 개념

기본키 무결성 제약조건


4. 참조 무결성 제약 조건

  • 한 테이블의 컬럼 값이 자신 또는 다른 테이블의 컬럼 값과 일치시키기 위한 제약 조건
  • 자식 테이블 : 다른 테이블의 컬럼 값을 참조하는 테이블
  • 부모 테이블 : 다른 테이블에 의해 참조되는 테이블
  • 외래 키 : 부모 테이블의 컬럼 값을 참조하는 자식 테이블의 컬럼
  • 참조 키 : 자식 테이블에서 참조하는 부모 테이블의 컬럼

- 갱신 제한과 삭제 제한에서 허용되는 DML 명령문

DML 명령 부모 테이블 자식 테이블
INSERT 참조 키 값이 고유 경우에만 가능 외래 키 값이 참조 키 값 중의 하나와 일치하거나 null인 경우에 가능
UPDATE 참조 키 값을 참조하는 자식 테이블의 컬럼 값이 없는 경우에만 가능 수정되는 외래 키 값이 참조 키 값 중 의 하나와 일치할 경우에 가능
DELETE
RESTRICT
참조 키 값을 참조하는 자식 테이블의 컬럼 값이 없는 경우에만 가능 항상 가능
DELETE
CASCADE
항상 가능 항상 가능

참조 무결성 제약조건


5. CHECK 무결성 제약 조건

  • 컬럼에서 허용 가능한 데이터의 범위나 조건을 지정
  • 데이터 입력이나 수정 시 실수로 부정확한 값 입력 예방
  • 하나의 컬럼에 여러 개의 CHECK 무결성 제약 조건을 지정 가능
  • CURRVAL, NEXTVAL과 같은 가상 컬럼이나 SYSDATE, USER와 같은 함수는 사용 불가능

CHECK 무결성 제약조건


728x90
'▣ SQL : Database/Oracle SQL🏮' 카테고리의 다른 글
  • [Oracle] RECURSIVE와 WITH, 재귀적으로 데이터 조회하기 [재귀 쿼리의 활용과 이해]
  • [Oracle] 실무에서 서브쿼리 사용 시 주의사항 [ORA-01427, ORA-00913, ORA-00907 해결방법]
  • [Oracle] SYSDATE와 CURRENT_DATE 차이 [데이터 서버 시간과 사용자 세션 시간의 차이]
  • [Oracle] SYS 계정과 SYSTEM 계정의 차이 [SYSOPER 권한과 SYSDBA 권한의 차이]
예르미(yermi)
예르미(yermi)
끊임없이 제 자신을 계발하는 개발자입니다👨🏻‍💻
  • 예르미(yermi)
    예르미의 코딩노트
    예르미(yermi)
  • 전체
    오늘
    어제
    • 분류 전체보기 (937)
      • ◎ Java (133)
        • Java☕ (93)
        • JSP📋 (26)
        • Applet🧳 (6)
        • Interview👨🏻‍🏫 (8)
      • ◎ JavaScript (48)
        • JavaScript🦎 (25)
        • jQuery🌊 (8)
        • React🌐 (2)
        • Vue.js🔰 (6)
        • Node.js🫒 (3)
        • Google App Script🐑 (4)
      • ◎ HTML5+CSS3 (17)
        • HTML5📝 (8)
        • CSS3🎨 (9)
      • ──────────── (0)
      • ▣ Framework (67)
        • Spring🍃 (36)
        • Spring Boot🍀 (12)
        • Bootstrap💜 (3)
        • Selenium🌕 (6)
        • MyBatis🐣 (10)
      • ▣ Tools (47)
        • API🎯 (18)
        • Library🎲 (15)
        • JitPack🚀 (3)
        • Jenkins👨🏻 (7)
        • Thymeleaf🌿 (4)
      • ▣ Server (32)
        • Apache Tomcat🐱 (14)
        • Apache HTTP Server🛡️ (1)
        • Nginx🧶 (7)
        • OracleXE💿 (4)
        • VisualSVN📡 (4)
      • ▣ OS : 운영체제 (18)
        • cmd : 명령프롬프트💻 (10)
        • Linux🐧 (8)
      • ▣ SQL : Database (56)
        • Oracle SQL🏮 (26)
        • PL SQL💾 (9)
        • MySQL🐬 (6)
        • MariaDB🦦 (6)
        • H2 Database🔠 (3)
        • SQL 실전문제🐌 (6)
      • ────────── (0)
      • ◈ Human Project (86)
        • Mini : Library Service📚 (15)
        • 화면 설계 [HTML]🐯 (10)
        • 서버 프로그램 구현🦁 (15)
        • Team : 여수어때🛫 (19)
        • Custom : Student🏫 (9)
        • Custom : Board📖 (18)
      • ◈ Yermi Project (40)
        • 조사모아(Josa-moa)📬 (5)
        • Riddle-Game🧩 (6)
        • 맛있을 지도🍚 (2)
        • 어디 가! 박대리!🙋🏻‍♂️ (5)
        • 조크베어🐻‍❄️ (4)
        • Looks Like Thirty🦉 (2)
        • Toy Project💎 (12)
        • 오픈소스 파헤치기🪐 (4)
      • ◈ Refactoring (15)
        • Mini : Library Service📚 (8)
        • 서버 프로그램 구현🦁 (1)
        • Team : 여수어때🛫 (0)
        • 쿼리 튜닝일지🔧 (6)
      • ◈ Coding Test (89)
        • 백준(BOJ)👨🏻‍💻 (70)
        • 프로그래머스😎 (2)
        • 코드트리🌳 (7)
        • 알고리즘(Algorithm)🎡 (10)
      • ◈ Study (102)
        • 기초튼튼 개발지식🥔 (25)
        • HTTP 웹 지식💡 (4)
        • 클린코드(Clean Code)🩺 (1)
        • 디자인패턴(GoF)🥞 (12)
        • 다이어그램(Diagram)📈 (4)
        • 파이썬(Python)🐍 (16)
        • 에러노트(Error Note)🧱 (34)
        • 웹 보안(Web Security)🔐 (6)
      • ◈ 공부모임 (39)
        • 혼공학습단⏰ (18)
        • 코드트리 챌린지👊🏻 (2)
        • 개발도서 100독👟 (8)
        • 나는 리뷰어다🌾 (11)
      • ◈ 자격증 공부 (37)
        • 정보처리기사🔱 (16)
        • 정보처리산업기사🔅 (9)
        • 컴퓨터활용능력 1급📼 (12)
      • ─────────── (0)
      • ◐ 기타 (113)
        • 알아두면 좋은 팁(tip)✨ (46)
        • 개발자의 일상🎈 (44)
        • 개발도서 서평🔍 (10)
        • 개발관련 세미나🎤 (2)
        • 블로그 꾸미기🎀 (9)
        • 사도신경 프로젝트🎚️ (2)
  • 인기 글

  • 최근 댓글

  • 태그

    javascript
    일상
    꿀팁
    SQL
    코딩
    Java
    Error Note
    Oracle
    jsp
    백준
    spring
    html
    자바스크립트
    Project
    BOJ
    백준 티어
    프로그래밍
    코딩 테스트
    CSS
    Database
  • 250x250
  • hELLO· Designed By정상우.v4.10.3
예르미(yermi)
[Oracle] 데이터 무결성 제약 조건의 종류 [primary key, unique key, foreign key, NOT NULL, CHECK]
상단으로

티스토리툴바