집 >데이터 베이스 >MySQL 튜토리얼 >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 중국어 웹사이트의 기타 관련 기사를 참조하세요!