Heim  >  Artikel  >  Datenbank  >  Wie können Zirkelverweise in SQL aufgelöst werden, insbesondere in MySQL?

Wie können Zirkelverweise in SQL aufgelöst werden, insbesondere in MySQL?

Patricia Arquette
Patricia ArquetteOriginal
2024-11-25 02:19:13336Durchsuche

How Can Circular References in SQL be Resolved, Especially in MySQL?

Zirkelverweise in SQL: Ein Dilemma

Im Bereich des relationalen Datenbankdesigns stellt sich die Frage: Ist es akzeptabel, dass zwei Tabellen vorhanden sind? sich gegenseitig verweisen? Die Antwort hängt leider vom jeweils verwendeten Datenbankmanagementsystem (DBMS) und der gewünschten Funktionalität ab.

Das Problem

Wie in der angegebenen Beispieldatenbankstruktur veranschaulicht , zwei Tabellen, products und products_pictures, haben Fremdschlüsseleinschränkungen, die einen Zirkelverweis erzeugen:

products.DEFAULT_PICTURE_ID -> products_pictures.ID
products_pictures.PRODUCT_ID -> products.ID

Dieser Zirkel kann insbesondere zu Problemen führen in MySQL.

Mögliche Lösungen

Option 1: Anpassbare Fremdschlüssel-Nullfähigkeit

Eine Lösung besteht darin, eine davon zu erstellen Fremdschlüsselspalten sind nullbar. Dies ermöglicht anfängliche INSERTs in beide Tabellen, ohne die Integritätsbeschränkung zu verletzen. Es kann jedoch zu Bedenken hinsichtlich der Datenintegrität führen, z. B. wenn es möglich ist, dass Produkte Standardbilder haben, die zu anderen Produkten gehören. Um dieses Problem zu beheben, kann die Fremdschlüsseleinschränkung wie folgt definiert werden:

CONSTRAINT FK_products_1 
  FOREIGN KEY (id, default_picture_id) 
  REFERENCES products_pictures (product_id, id)
  ON DELETE RESTRICT
  ON UPDATE RESTRICT

Option 2: IsDefault Flag

Ein anderer Ansatz besteht darin, die Spalte DEFAULT_PICTURE_ID in zu ersetzen die Produkttabelle mit einem IsDefault-Flag in der Tabelle products_pictures. Diese Lösung erfordert die Definition einer eindeutigen Einschränkung oder eines eindeutigen Index, um sicherzustellen, dass nur für ein Bild pro Produkt das IsDefault-Flag auf „true“ gesetzt ist. Allerdings unterstützt MySQL keine Teilindizes, was diesen Ansatz unpraktisch macht.

Option 3: Aufschiebbare Einschränkungen

Diese Option beinhaltet die Verwendung aufschiebbarer Einschränkungen. Aufschiebbare Einschränkungen ermöglichen es der Datenbank, die Durchsetzung der Integritätsbeschränkung vorübergehend zu verzögern, sodass die anfängliche Einrichtung der Tabellen und ihrer Beziehungen möglich ist. Allerdings unterstützt MySQL keine aufschiebbaren Einschränkungen.

Option 4: Zwischentabelle

Um Zirkelverweise vollständig zu eliminieren, kann eine dritte Tabelle eingeführt werden:

product_default_picture
----------------------
product_id          NOT NULL
default_picture_id  NOT NULL
PRIMARY KEY (product_id)
FOREIGN KEY (product_id, default_picture_id)
  REFERENCES products_pictures (product_id, id)

Dieser Ansatz beseitigt die Zirkularität und stellt die Datenintegrität sicher.

MySQL Empfehlungen

Für MySQL bleiben zwei Optionen realisierbar:

  • Option 1: Anpassbare Fremdschlüssel-Nullbarkeit mit der oben beschriebenen Korrektur, um die Datenintegrität zu erzwingen.
  • Option 4: Zwischentabelle, um Zirkelverweise gänzlich zu vermeiden.

Das obige ist der detaillierte Inhalt vonWie können Zirkelverweise in SQL aufgelöst werden, insbesondere in MySQL?. 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