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:
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!