Heim >Datenbank >MySQL-Tutorial >Können MySQL InnoDB-Fremdschlüssel datenbankübergreifend sein?

Können MySQL InnoDB-Fremdschlüssel datenbankübergreifend sein?

DDD
DDDOriginal
2024-11-13 11:25:02895Durchsuche

Can MySQL InnoDB Foreign Keys Span Across Databases?

MySQL InnoDB-Fremdschlüssel über Datenbanken hinweg

In MySQL InnoDB können Sie Fremdschlüssel zwischen Tabellen in verschiedenen Datenbanken erstellen. Dadurch können Sie die referenzielle Integrität auch dann erzwingen, wenn sich die Tabellen in separaten Datenbanken befinden. Um dies zu erreichen:

CREATE TABLE example_table (
  id INT PRIMARY KEY,
  other_id INT,
  FOREIGN KEY (other_id) REFERENCES otherdb.othertable(id)
);

Im obigen Beispiel verfügt die example_table in Ihrer aktuellen Datenbank über einen Fremdschlüssel, der auf die Spalte other_id in der othertable in der otherdb-Datenbank verweist. Die otherdb.othertable muss vorhanden sein und ihre ID-Spalte muss ein Primärschlüssel oder ein eindeutiger Index sein.

Dadurch können Sie die referenzielle Integrität aufrechterhalten, selbst wenn Sie die Tabellen in andere Datenbanken verschieben. In der MySQL-Dokumentation werden keine Einschränkungen für Fremdschlüsselverweise in Datenbanken angegeben. Daher können Sie die Syntax otherdb.othertable sicher verwenden, um datenbankübergreifende Fremdschlüsselbeziehungen herzustellen.

Das obige ist der detaillierte Inhalt vonKönnen MySQL InnoDB-Fremdschlüssel datenbankübergreifend sein?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn