sql-logo
SQL에서 기본키(Primary Key)는 테이블 내의 각 행을 고유하게 식별하는 역할을 합니다. 기본키는 테이블의 중복된 데이터를 방지하고, 데이터의 무결성을 보장하는 데 중요한 역할을 합니다.
외래키(Foreign Key)는 관계형 데이터베이스에서 하나의 테이블의 필드(또는 필드 집합)가 다른 테이블의 기본키를 참조하는데 사용되는 키입니다. 이는 테이블 간의 관계를 설정하고 데이터의 무결성을 유지하는 데 도움이 됩니다.
기본키(Primary Key)는 데이터베이스 테이블의 각 행을 고유하게 식별하는 데 사용되며, 데이터의 정확성과 무결성을 유지하는 데 중요한 역할을 합니다.
테이블을 생성할 때, CREATE TABLE 문을 사용하여 기본키를 정의합니다. 기본키는 해당 테이블의 주요 식별자가 되며 다음과 같은 예시로 정의할 수 있습니다.
CREATE TABLE 사용자 (
사용자ID INT PRIMARY KEY,
이름 VARCHAR(50),
이메일 VARCHAR(100)
);
SQL일반적으로 숫자로 된 기본키는 AUTO_INCREMENT 속성을 사용하여 자동으로 증가하도록 설정합니다. 이렇게 하면 데이터베이스가 새로운 레코드를 삽입할 때 자동으로 기본키 값을 증가시킵니다.
CREATE TABLE 주문 (
주문ID INT AUTO_INCREMENT PRIMARY KEY,
날짜 DATE,
사용자ID INT
);
SQL이미 존재하는 테이블에 기본키를 추가하려면 ALTER TABLE 문을 사용할 수 있습니다.
ALTER TABLE 주문
ADD PRIMARY KEY (주문ID);
SQL두 개 이상의 열을 결합하여 복합 기본키를 정의할 수 있습니다.
CREATE TABLE 주문_상세 (
주문ID INT,
상품ID INT,
PRIMARY KEY (주문ID, 상품ID)
);
SQLALTER TABLE 사용자
DROP PRIMARY KEY;
SQLALTER TABLE 주문
MODIFY PRIMARY KEY (다른ID);
SQL외래키(Foreign Key)는 데이터베이스에서 두 테이블 간의 관계를 설정하고 연결하는 데 사용되며, 데이터의 일관성과 무결성을 유지하는 데 중요한 역할을 합니다. 외래키를 사용하는 방법에 대해 자세히 설명하겠습니다:
테이블을 생성할 때, CREATE TABLE 문을 사용하여 외래키를 정의합니다. 외래키는 참조할 테이블과 참조할 열을 명시합니다.
CREATE TABLE 주문 (
주문ID INT PRIMARY KEY,
날짜 DATE,
사용자ID INT,
FOREIGN KEY (사용자ID) REFERENCES 사용자(사용자ID)
);
SQL이미 존재하는 테이블에 외래키를 추가하려면 ALTER TABLE 문을 사용할 수 있습니다.
ALTER TABLE 주문
ADD FOREIGN KEY (사용자ID) REFERENCES 사용자(사용자ID);
SQL외래키는 보통 제약 조건(constraint)으로 사용되어 데이터 무결성을 보장합니다.
CREATE TABLE 주문 (
주문ID INT PRIMARY KEY,
날짜 DATE,
사용자ID INT,
FOREIGN KEY (사용자ID) REFERENCES 사용자(사용자ID)
ON DELETE CASCADE
ON UPDATE NO ACTION
);
SQL✔️위의 예시에서 ON DELETE CASCADE는 참조된 키가 삭제될 때 주문 테이블의 해당 행도 삭제되도록 설정한 것입니다.
두 개 이상의 열을 결합하여 복합 외래키를 정의할 수 있습니다.
CREATE TABLE 주문_상세 (
주문ID INT,
상품ID INT,
PRIMARY KEY (주문ID, 상품ID),
FOREIGN KEY (주문ID) REFERENCES 주문(주문ID),
FOREIGN KEY (상품ID) REFERENCES 상품(상품ID)
);
SQLALTER TABLE 주문
DROP FOREIGN KEY 주문_사용자_fk;
SQLALTER TABLE 주문
DROP FOREIGN KEY 주문_사용자_fk;
SQL외래키를 적절하게 활용하면 데이터베이스의 관계를 잘 구성하고 데이터의 일관성을 유지할 수 있습니다.
기본키와 외래키는 데이터베이스의 핵심 원리로, 데이터의 정확성과 무결성을 보장합니다. 기본키는 각 레코드를 식별하고, 외래키는 테이블 간의 관계를 형성하여 데이터 일관성을 유지합니다. 적절한 활용을 통해 데이터베이스의 구조를 명확하게 설계하고 효율적으로 관리할 수 있습니다.
Readable Code: 읽기 좋은 코드를 작성하는 사고법Practical Testing: 실용적인 테스트 가이드 강의와 함께한 인프런 워밍업 클럽…
Readable Code: 읽기 좋은 코드를 작성하는 사고법Practical Testing: 실용적인 테스트 가이드 강의와 함께한 인프런 워밍업 클럽…
테스트 시 의존성 주입(Dependency Injection)과 Mockito Spring 애플리케이션을 개발하다 보면, 테스트 코드에서 실제 빈(Bean)을 사용하지…
들어가며 스프링 기반 프로젝트에서 좋은 설계 구조와 테스트 전략은 소프트웨어 품질과 유지보수성에 직결됩니다. 최근 학습한…
Readable Code: 읽기 좋은 코드를 작성하는 사고법Practical Testing: 실용적인 테스트 가이드 강의와 함께한 인프런 워밍업 클럽…
Readable Code: 읽기 좋은 코드를 작성하는 사고법Practical Testing: 실용적인 테스트 가이드 강의와 함께한 인프런 워밍업 클럽…