1. 학습
  2. /
  3. 강의
  4. /
  5. PostgreSQL 데이터베이스 만들기

Connected

연습 문제

지나친 정규화

loan 테이블 정의를 다시 떠올려 보세요.

CREATE TABLE loan (
    borrower_id INTEGER REFERENCES borrower(id),
    bank_id INTEGER REFERENCES bank(id),
    approval_date DATE NOT NULL DEFAULT CURRENT_DATE,
    gross_approval DECIMAL(9, 2) NOT NULL,
    term_in_months SMALLINT NOT NULL,
    revolver_status BOOLEAN NOT NULL DEFAULT FALSE,
    initial_interest_rate DECIMAL(4, 2) NOT NULL
);

이 테이블이 1NF를 만족하도록 새 설계안이 제시되었습니다. 수정된 테이블 정의는 approval_date를 approval_month, approval_day, approval_year로 대체합니다:

CREATE TABLE loan (
    ...
    approval_month SMALLINT,
    approval_day SMALLINT,
    approval_year SMALLINT,
    ...
);

이 연습 문제는 과도한 정규화가 어떻게 잘못된 데이터의 삽입을 허용할 수 있는지를 보여 줍니다.

지침

100 XP
  • 테이블에 잘못된 데이터가 삽입되도록 만드는 INSERT INTO 문을 삭제하세요.