Heim > Backend-Entwicklung > PHP-Tutorial > Baumdatenstruktur-Speichermethode (CUD)

Baumdatenstruktur-Speichermethode (CUD)

藏色散人
Freigeben: 2023-04-07 11:54:02
nach vorne
2892 Leute haben es durchsucht

Im vorherigen Artikel wurde kurz das Datenmodell verschachtelter Sammlungen und die Abfragemethode Portal vorgestellt: Baumdatenstruktur-Speichermethode (Abfrage)

Erstellen

Im verschachtelten Sammlungsmodell sind alle Daten tatsächlich ein Knoten, und jeder Knoten belegt 2 Bitwerte. Beginnen wir beispielsweise mit dem Hinzufügen eines Knotens der ersten Ebene für Smartphones.

INSERT INTO `categories` (`title`, `lft`, `rgt`) VALUES('Smartphones', 1, 2);
Nach dem Login kopieren

Smartphones Als Master-Knoten (Root) muss sein LFT 1 sein, und der Wert von rgt erhöht sich, wenn die Anzahl der untergeordneten Elemente in seiner Sammlung zunimmt.

Jetzt möchten wir ein untergeordnetes Android-Element in Smartphones hinzufügen. Verwenden Sie gespeicherte MySQL-Prozeduren.

LOCK TABLE categories WRITE;
SELECT @root_left := lft FROM categories WHERE title = 'Smartphones';
UPDATE categories SET rgt = rgt + 2 WHERE rgt > @root_left;
UPDATE categories SET lft = lft + 2 WHERE lft > @root_left;
INSERT INTO categories (title, lft, rgt) VALUES('Android', @root_left + 1, @root_left + 2);
UNLOCK TABLES;
SELECT `title`, `lft`, `rgt` FROM `categories`;
+-------------+-----+-----+
| title       | lft | rgt |
+-------------+-----+-----+
| Smartphones |   1 |   4 |
| Android     |   2 |   3 |
+-------------+-----+-----+
Nach dem Login kopieren

Wir versuchen erneut, ein Unterelement Xiaomi zu Android hinzuzufügen:

LOCK TABLE categories WRITE;
SELECT @root_left := lft FROM categories WHERE title = 'Android';
UPDATE categories SET rgt = rgt + 2 WHERE rgt > @root_left;
UPDATE categories SET lft = lft + 2 WHERE lft > @root_left;
INSERT INTO categories (title, lft, rgt) VALUES('小米', @root_left + 1, @root_left + 2);
UNLOCK TABLES;
SELECT `title`, `lft`, `rgt` FROM `categories`;
+-------------+-----+-----+
| title       | lft | rgt |
+-------------+-----+-----+
| Smartphones |   1 |   6 |
| Android     |   2 |   5 |
| 小米        |   3 |   4 |
+-------------+-----+-----+
Nach dem Login kopieren

Zu diesem Zeitpunkt versuchen wir, ein Unterelement iOS zu Smartphones hinzuzufügen. Zuvor haben wir es innen hinzugefügt Ein Android-Element, daher müssen wir hier die gespeicherte Prozedur anpassen und iOS rechts von Android einfügen kann tatsächlich als der umgekehrte Prozess des Hinzufügens neuer Knoten angesehen werden. Wir führen eine Breite ein, um die Breite des Knotens zu messen, die ausgedrückt wird als: rgt - lft + 1. Wir können die gespeicherte Prozedur also wie folgt schreiben:

LOCK TABLE categories WRITE;
SELECT @next_right := rgt FROM categories WHERE title = 'Android';
UPDATE categories SET rgt = rgt + 2 WHERE rgt > @next_right;
UPDATE categories SET lft = lft + 2 WHERE lft > @next_right;
INSERT INTO categories(title, lft, rgt) VALUES('iOS', @next_right + 1, @next_right + 2);
UNLOCK TABLES;
SELECT `title`, `lft`, `rgt` FROM `categories`;
+-------------+-----+-----+
| title       | lft | rgt |
+-------------+-----+-----+
| Smartphones |   1 |   8 |
| Android     |   2 |   5 |
| 小米        |   3 |   4 |
| iOS         |   6 |   7 |
+-------------+-----+-----+
Nach dem Login kopieren

Update

Das Verschieben von Knoten ist ein relativ komplizierter Vorgang. In der Abbildung unten sollte macOS beispielsweise der Kategorie Unix zugeordnet werden.


Um den Knoten zu verschieben, sind drei Schritte erforderlich:

1. Nehmen Sie den zu verschiebenden Knoten heraus

2 und rgt-ParameterBaumdatenstruktur-Speichermethode (CUD)

3. Verschieben Sie den Knoten an die angegebene Position

LOCK TABLE categories WRITE;
SELECT @delete_left := lft, @delete_right := rgt, @delete_width := rgt - lft + 1
FROM categories WHERE title = 'Android';
DELETE FROM categories WHERE lft BETWEEN @delete_left AND @delete_right;
UPDATE categories SET rgt = rgt - @delete_width WHERE rgt > @delete_right;
UPDATE categories SET lft = lft - @delete_width WHERE lft > @delete_right;
UNLOCK TABLES;
SELECT `title`, `lft`, `rgt` FROM `categories`;
+-------------+-----+-----+
| title       | lft | rgt |
+-------------+-----+-----+
| Smartphones |   1 |   4 |
| iOS         |   2 |   3 |
+-------------+-----+-----+
Nach dem Login kopieren

Zusammenfassung

Tatsächlich hat das Datenmodell verschachtelter Sammlungen in SQL Seit langem vorgeschlagen, gibt es viele Pakete, die diese Funktion implementiert haben, wie z. B. laravel-nestedset oder django-mptt

Für den Produktionsgebrauch gibt es definitiv kein so einfaches Tabellenstrukturdesign oder sogar andere Optimierungen , wie zum Beispiel ein sogenanntes Es handelt sich um ein geschlossenes Tabellendatenmodell, das in dieser Artikelserie jedem vorgestellt werden sollte.

Das obige ist der detaillierte Inhalt vonBaumdatenstruktur-Speichermethode (CUD). Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:learnku.com
Erklärung dieser Website
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage