@ VasiliiSuricov- You can change this option with ALTER TABLE, but in that case the new value must be higher than the highest value which is present in the AUTO_INCREMENT column.Quelle Wenn es keinen höheren Wert gibt als den, den Sie für Ihre auto_incremented-Spalte festlegen möchten , können Sie den Wert auch verringern. ( MySQL-Dokumentation )
Seyfahni
Antworten:
519
Sie können ALTER TABLEden Anfangswert von auto_increment ändern:
ALTERTABLE tbl AUTO_INCREMENT =5;
Weitere Informationen finden Sie in der MySQL-Referenz .
Weiß jemand, ob es möglich ist, OHNE ÄNDERUNG zu tun?
Thesmart
3
Ja es ist möglich. Siehe meine Antwort.
Cosimo
3
MySQL 5.6 hatte einen Fehler, durch den Sie den AUTO_INCREMENTWert nicht verringern konnten. Er wurde jedoch in 5.6.16 und 5.7.4 behoben. Siehe bugs.mysql.com/bug.php?id=69882
Daniel Vandersluis
3
Schauen Sie sich die Warnung von cosimo an, dass der Tisch in diesem Fall wieder aufgebaut wird!
h00ligan
15
Zur Verdeutlichung: Wenn Sie den Anfangswert auf 5 setzen, bedeutet dies, dass die nächste Einfügung 5 ist.
Steen Schütt
97
Ja, Sie können die ALTER TABLE t AUTO_INCREMENT = 42Anweisung verwenden. Sie müssen sich jedoch bewusst sein, dass dies die Neuerstellung Ihrer gesamten Tabelle verursacht, zumindest mit InnoDB und bestimmten MySQL-Versionen. Wenn Sie über ein bereits vorhandenes Dataset mit Millionen von Zeilen verfügen, kann die Fertigstellung sehr lange dauern .
Nach meiner Erfahrung ist es besser, Folgendes zu tun:
BEGIN WORK;-- You may also need to add other mandatory columns and valuesINSERTINTO t (id)VALUES(42);ROLLBACK;
Auf diese Weise behält MySQL den Wert für die automatische Inkrementierung bei , selbst wenn Sie die Transaktion zurücksetzen, und die Änderung wird sofort angewendet.
Sie können dies überprüfen, indem Sie eine SHOW CREATE TABLE tErklärung abgeben. Das solltest du sehen:
> SHOW CREATETABLE t \G***************************1.row***************************Table: tCreateTable:CREATETABLE`t`(...) ENGINE=InnoDB AUTO_INCREMENT=43...
VIELEN DANK! SET foreign_key_checks = 0;ist auch dafür nützlich.
dnozay
Brilliante Idee! Nitpick: Gibt SHOW CREATE TABLE ttatsächlich zurück 43, dh den nächsten Wert nach dem Einfügen 42.
Petrkotek
2
@cosimo, Warte, ist das nicht undokumentiert ? Hat das Handbuch gesagt, dass es so funktionieren soll? Wenn nicht, kann es zu einem anderen (zukünftigen) MySQL-Setup kommen.
Pacerier
1
@ Pacerier ja, du bist richtig. Dies hängt von der aktuellen Funktionsweise von MySQL ab. So könnte es in Zukunft nicht mehr funktionieren. Angesichts der MySQL-Geschichte würde ich jedoch davon ausgehen, dass dies noch lange so funktioniert.
Cosimo
@cosimo, hoffentlich würden sie es dokumentieren, damit zuverlässiger Code diesen guten Hack tatsächlich nutzen kann. Code, der zuverlässig sein möchte, kann dies derzeit nicht verwenden.
Pacerier
13
So erhöhen Sie automatisch um eins, beginnend bei 10 in MySQL:
createtable foobar(
id INT PRIMARYKEY AUTO_INCREMENT,
moobar VARCHAR(500));ALTERTABLE foobar AUTO_INCREMENT=10;INSERTINTO foobar(moobar)values("abc");INSERTINTO foobar(moobar)values("def");INSERTINTO foobar(moobar)values("xyz");select*from foobar;'10','abc''11','def''12','xyz'
Dadurch wird die ID-Spalte ab 10 automatisch um eins erhöht.
Automatisches Inkrementieren in MySQL um 5 ab 10:
droptable foobarcreatetable foobar(
id INT PRIMARYKEY AUTO_INCREMENT,
moobar VARCHAR(500));SET@@auto_increment_increment=5;ALTERTABLE foobar AUTO_INCREMENT=10;INSERTINTO foobar(moobar)values("abc");INSERTINTO foobar(moobar)values("def");INSERTINTO foobar(moobar)values("xyz");select*from foobar;'11','abc''16','def''21','xyz'
Dadurch wird die ID-Spalte jedes Mal automatisch um 5 erhöht, beginnend bei 10.
Sie können dies auch mit phpmyadmin tun. Wählen Sie einfach die Tabelle aus und gehen Sie zu den Aktionen. Ändern Sie die Optionen für das automatische Inkrement unter den Tabellen. Vergessen Sie nicht, auf Start zu klicken
You can change this option with ALTER TABLE, but in that case the new value must be higher than the highest value which is present in the AUTO_INCREMENT column.
Quelle Wenn es keinen höheren Wert gibt als den, den Sie für Ihreauto_increment
ed-Spalte festlegen möchten , können Sie den Wert auch verringern. ( MySQL-Dokumentation )Antworten:
Sie können
ALTER TABLE
den Anfangswert von auto_increment ändern:Weitere Informationen finden Sie in der MySQL-Referenz .
quelle
AUTO_INCREMENT
Wert nicht verringern konnten. Er wurde jedoch in 5.6.16 und 5.7.4 behoben. Siehe bugs.mysql.com/bug.php?id=69882Ja, Sie können die
ALTER TABLE t AUTO_INCREMENT = 42
Anweisung verwenden. Sie müssen sich jedoch bewusst sein, dass dies die Neuerstellung Ihrer gesamten Tabelle verursacht, zumindest mit InnoDB und bestimmten MySQL-Versionen. Wenn Sie über ein bereits vorhandenes Dataset mit Millionen von Zeilen verfügen, kann die Fertigstellung sehr lange dauern .Nach meiner Erfahrung ist es besser, Folgendes zu tun:
Auf diese Weise behält MySQL den Wert für die automatische Inkrementierung bei , selbst wenn Sie die Transaktion zurücksetzen, und die Änderung wird sofort angewendet.
Sie können dies überprüfen, indem Sie eine
SHOW CREATE TABLE t
Erklärung abgeben. Das solltest du sehen:quelle
SET foreign_key_checks = 0;
ist auch dafür nützlich.SHOW CREATE TABLE t
tatsächlich zurück43
, dh den nächsten Wert nach dem Einfügen42
.So erhöhen Sie automatisch um eins, beginnend bei 10 in MySQL:
Dadurch wird die ID-Spalte ab 10 automatisch um eins erhöht.
Automatisches Inkrementieren in MySQL um 5 ab 10:
Dadurch wird die ID-Spalte jedes Mal automatisch um 5 erhöht, beginnend bei 10.
quelle
Prozedur zum automatischen Fixieren des AUTO_INCREMENT-Werts der Tabelle
quelle
Wenn Sie dieses Verfahren für variable Feldnamen benötigen, kann dies
id
hilfreich sein:quelle
Sie können dies auch mit phpmyadmin tun. Wählen Sie einfach die Tabelle aus und gehen Sie zu den Aktionen. Ändern Sie die Optionen für das automatische Inkrement unter den Tabellen. Vergessen Sie nicht, auf Start zu klicken
quelle
Exportieren Sie einfach die Tabelle mit Daten. Kopieren Sie dann die SQL-Datei
Ändern Sie nun den Wert für das automatische Inkrementieren und führen Sie SQL aus.
quelle