>데이터 베이스 >MySQL 튜토리얼 >MySQL InnoDB에서 데이터베이스 간 외래 키 관계를 어떻게 생성합니까?

MySQL InnoDB에서 데이터베이스 간 외래 키 관계를 어떻게 생성합니까?

DDD
DDD원래의
2024-11-14 16:37:02555검색

How do I create Inter-Database Foreign Key Relationships in MySQL InnoDB?

MySQL InnoDB의 데이터베이스 간 외래 키 관계

MySQL InnoDB는 서로 다른 데이터베이스에 있는 테이블 간에 외래 키 제약 조건을 설정하는 기능을 제공합니다. 이 기능을 사용하면 외부 источников에서 데이터를 참조할 때 데이터 무결성을 유지할 수 있습니다.

데이터베이스 간 외래 키 생성

데이터베이스 간 외래 키를 생성하려면 다음을 지정하기만 하면 됩니다. 다음과 같이 정규화된 이름을 사용하여 다른 데이터베이스의 대상 테이블:

ALTER TABLE my_table
ADD FOREIGN KEY (fk_column)
REFERENCES other.other_table(pk_column)

이 예에서 other는 다른 데이터베이스의 이름이고 other_table은 대상 테이블이고 pk_column은 기본 키입니다. 대상 테이블이고 fk_column은 my_table의 외래 키 열입니다.

sales와 Customer라는 두 개의 데이터베이스가 있고 Inter를 생성하려고 한다고 가정합니다. -판매 데이터베이스의 주문 테이블에서 고객 데이터베이스의 고객 테이블로의 데이터베이스 외래 키입니다. 다음 SQL 문을 사용하여 이 작업을 수행할 수 있습니다.

ALTER TABLE sales.orders
ADD FOREIGN KEY (customer_id)
REFERENCES customers.customers(customer_id)

이제 고객 테이블에 존재하지 않는 고객을 참조하는 주문 테이블의 모든 레코드는 유효하지 않은 것으로 간주되어 데이터베이스에 삽입되지 않습니다. .

제한 사항

InnoDB에서 데이터베이스 간 외래 키 생성에 대한 문서화된 제한 사항이 없다는 점에 유의하는 것이 중요합니다. 그러나 특히 데이터베이스가 서로 다른 서버에 있는 경우 이러한 관계가 성능에 미치는 영향을 고려하는 것이 좋습니다.

위 내용은 MySQL InnoDB에서 데이터베이스 간 외래 키 관계를 어떻게 생성합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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