Automatische Inkrementierung nach Gruppe in MySQL
MySQL bietet eine praktische Möglichkeit, einen Feldwert basierend auf einer Gruppierungsspalte automatisch zu erhöhen. Dies ist besonders nützlich in Szenarien, in denen Datensätze innerhalb jeder Gruppe gruppiert und nummeriert werden müssen.
Für MyISAM- und BDB-Tabellen
Für MyISAM- und BDB-Tabellen automatische Inkrementierung kann als sekundärer Schlüsselteil definiert werden. Betrachten Sie beispielsweise die folgende Tabellenstruktur:
CREATE TABLE foo ( id INT AUTO_INCREMENT NOT NULL, group_field INT NOT NULL, name VARCHAR(128), PRIMARY KEY(group_field, id) );
In dieser Struktur ist das ID-Feld als Auto-Inkrement definiert, aber es ist zusammen mit dem Gruppenfeld auch Teil des Primärschlüssels. Gemäß der MySQL-Dokumentation:
In this case, the generated value for the AUTO_INCREMENT column is calculated as MAX(auto_increment_column) + 1 WHERE prefix=given-prefix. This is useful when you want to put data into ordered groups.
Beispiel
Fügen wir unter Verwendung der oben erstellten foo-Tabelle einige Beispieldaten ein:
INSERT INTO foo (group_field, name) VALUES (1, 'test'), (1, 'test2'), (2, 'test3'), (2, 'test4'), (3, 'test5'), (3, 'test6');
Nach dem Einfügen der Daten sieht der Inhalt der foo-Tabelle wie folgt aus:
+----+-----------+------+ | id | group_field | name | +----+-----------+------+ | 1 | 1 | test | | 2 | 1 | test2 | | 3 | 2 | test3 | | 4 | 2 | test4 | | 5 | 3 | test5 | | 6 | 3 | test6 | +----+-----------+------+
Wie Sie sehen können, wurde die ID-Spalte innerhalb jeder Gruppe automatisch erhöht, basierend auf dem Gruppenfeldwert.
Das obige ist der detaillierte Inhalt vonWie implementiert man die automatische Inkrementierung nach Gruppen in MySQL?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!