Heim > Datenbank > MySQL-Tutorial > Was soll ich tun, wenn MySQL keine automatisch inkrementierten IDs mehr hat?

Was soll ich tun, wenn MySQL keine automatisch inkrementierten IDs mehr hat?

Guanhui
Freigeben: 2020-06-03 10:42:15
Original
4283 Leute haben es durchsucht

Was soll ich tun, wenn MySQL keine automatisch inkrementierten IDs mehr hat?

Was soll ich tun, wenn MySQL keine automatisch inkrementierten IDs mehr hat?

Es gibt viele Arten von Auto-Inkrement-IDs in MySQL. Für jede Auto-Inkrement-ID ist ein Anfangswert festgelegt, der dann entsprechend einer bestimmten Schrittgröße erhöht wird, solange die Bytelänge definiert ist Wenn die Obergrenze erreicht und erneut hinzugefügt wird, wird ein Primärschlüsselkonfliktfehler gemeldet. Als Lösung sollten Sie die Verwendung des Typs „bigint unsigned“ in Betracht ziehen.

Test

Die durch die Datentabelle definierte Auto-Inkrement-ID, wenn die Obergrenze erreicht ist.

Bei der Beantragung des nächsten Ausweises bleibt der erhaltene Wert unverändert.

Wir können es anhand des folgenden Beispiels überprüfen:

create table `test` (
   `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
   PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=4294967295;
 
insert into `test` values (null);
Nach dem Login kopieren

An diesem Ergebnis können Sie erkennen, dass der ID-Wert immer noch 4294967295 ist, wenn Daten zum ersten Mal eingefügt werden

Wenn Daten zweimal eingefügt werden, wird ein Primärschlüsselkonfliktfehler gemeldet.

Dies bedeutet, dass sich der ID-Wert nicht mehr ändert, nachdem er die Obergrenze erreicht hat.

Empfohlenes Tutorial: „MySQL-Tutorial

Das obige ist der detaillierte Inhalt vonWas soll ich tun, wenn MySQL keine automatisch inkrementierten IDs mehr hat?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
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