>데이터 베이스 >MySQL 튜토리얼 >기존 SQLite 테이블에 외래 키를 어떻게 추가합니까?

기존 SQLite 테이블에 외래 키를 어떻게 추가합니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2025-01-05 07:33:40995검색

How Do I Add a Foreign Key to an Existing SQLite Table?

기존 SQLite 테이블에 외래 키 추가

도전 과제:

기존 SQLite 테이블로 작업하고 있습니다. , 특정 항목에 외래 키 제약 조건을 추가해야 합니다.

해결책:

다른 SQL 구현과 달리 SQLite는 ALTER TABLE 명령의 ADD CONSTRAINT 변형을 지원하지 않습니다. 따라서 기존 테이블에 외래 키 제약 조건을 직접 추가하는 것은 불가능합니다.

대체 접근 방식:

원하는 결과를 얻으려면 다음 단계를 따라야 합니다.

  1. 기존 테이블의 데이터를 임시 테이블에 저장합니다. table.
  2. 기존 테이블을 삭제합니다.
  3. 외래 키 제약 조건이 포함된 테이블을 다시 만듭니다.
  4. 임시 테이블의 데이터를 새 테이블에 다시 삽입합니다.

이 프로세스에 대한 예제 SQL:

-- Step 1: Create a temporary table
CREATE TEMPORARY TABLE t_child AS SELECT * FROM child;

-- Step 2: Drop the existing table
DROP TABLE child;

-- Step 3: Recreate the table with the foreign key constraint
CREATE TABLE child (
    id INTEGER PRIMARY KEY,
    parent_id INTEGER,
    description TEXT,
    FOREIGN KEY (parent_id) REFERENCES parent(id)
);

-- Step 4: Insert data back from the temporary table
INSERT INTO child SELECT * FROM t_child;

다음을 실행하여 단계를 거치면 기본적으로 원본 테이블의 데이터를 보존하면서 원하는 외래 키 제약 조건을 사용하여 새 테이블을 생성할 수 있습니다.

위 내용은 기존 SQLite 테이블에 외래 키를 어떻게 추가합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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