>데이터 베이스 >MySQL 튜토리얼 >SQL Server에서 외래 키 제약 조건을 설정하는 방법은 무엇입니까?

SQL Server에서 외래 키 제약 조건을 설정하는 방법은 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2025-01-01 12:40:111031검색

How to Establish Foreign Key Constraints in SQL Server?

SQL Server에서 외래 키 제약 조건 설정

데이터 무결성을 유지하는 것은 모든 데이터베이스 시스템에서 매우 중요합니다. SQL Server는 외래 키 제약 조건을 사용하여 테이블 간의 관계를 적용하는 기능을 제공합니다. 그러나 외래 키 선언은 PostgreSQL과 같은 다른 데이터베이스 관리 시스템과 다릅니다.

구문 및 고려 사항

SQL Server에서 외래 키를 생성하는 방법은 다음과 같습니다.

ALTER TABLE <child_table>
ADD CONSTRAINT <constraint_name>
FOREIGN KEY (<child_column>)
REFERENCES <parent_table>(<parent_column>)

하위 테이블의 참조 열 수가 상위 테이블의 참조 열 수와 일치하는지 확인하세요. 테이블. 그렇지 않으면 다음과 유사한 오류가 발생합니다.

Msg 8139, Level 16, State 0, Line 9
Number of referencing columns in foreign key differs from number of referenced columns, table 'question_bank'.

문제 해결: 잘못된 구문

question_bank 테이블 생성을 위해 제공된 SQL 코드에 오류가 있습니다. 질문_뱅크 테이블의 질문_exam_id 열은 시험 테이블의 Exam_id 열을 참조해야 합니다.

create table question_bank
(
    question_id uniqueidentifier primary key,
    question_exam_id uniqueidentifier not null, <!-- This should be a foreign key -->
    question_text varchar(1024) not null,
    question_point_value decimal,
    constraint question_exam_id foreign key references exams(exam_id)
);

대체 구문: 나중에 제약 조건 추가

외래 키를 생성할 수도 있습니다. ALTER TABLE을 사용하여 하위 테이블을 생성한 후의 제약 조건 명령문:

alter table question_bank
add constraint question_exam_id_fk foreign key (question_exam_id) references exams(exam_id)

이 방법을 사용하면 테이블 생성과 별도로 제약 조건을 정의하여 데이터베이스 스키마에 대한 유연성과 제어력을 높일 수 있습니다.

위 내용은 SQL Server에서 외래 키 제약 조건을 설정하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.