Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi mysql autoincrement maximalwert erreicht (https://www.delphipraxis.net/91318-mysql-autoincrement-maximalwert-erreicht.html)

query 3. Mai 2007 11:18

Datenbank: MySQL • Version: 5.1 • Zugriff über: libmysql.dll

mysql autoincrement maximalwert erreicht
 
Hallo,
ich verwende in mehreren MySQL-Tabellen BIGINT(20) als Primärschlüssel mit auto_increment. Kann mir hier jemand sagen, welchen Wert MySQL in diese Felder schreibt, wenn der Maximalwert erreicht wurde? Fängt MySQL dann automatisch wieder bei eins an zu zählen?

himitsu 3. Mai 2007 12:39

Re: mysql autoincrement maximalwert erreicht
 
Einfach mal testen?

SQL-Code:
CREATE TABLE `test` (
  `a` BIGINT(20) NOT NULL AUTO_INCREMENT PRIMARY KEY,
  `b` INT NOT NULL
) TYPE = MYISAM;

INSERT INTO `test` (`a`, `b`) VALUES (99999999999999999998, 1);
Antwort:
Zitat:

Eingefügte Zeilen: 1
Letzte automatisch eingefügte ID: -1 (die Abfrage dauerte 0.0009 sek)
in Tabelle drin:
Zitat:

a = 9.223.372.036.854.775.807 | b = 2

Status:
Zitat:

Nächste Autoindex = -9.223.372.036.854.776.000

BIGINT(20) würde ja einen 20-Stelligen Integer beteuten, nur kann ein 64-BitInteger nur -9223372036854775808 bis 9223372036854775807 sein.

Also gibt es dann 'nen Umbruch in den ersten negativen Wert.

bei meinem Test wurde der einzufügende Weert vorher halt nur noch in den Wertebereich runtergerundet.


[add]
Also hier müßtest du dann wohl genau sehn, wie mySQL reagiert:
SQL-Code:
CREATE TABLE `test` ( 
  `a` BIGINT(20) NOT NULL AUTO_INCREMENT PRIMARY KEY,
  `b` INT NOT NULL
) TYPE = MYISAM;

INSERT INTO `test` (`a`, `b`) VALUES (9223372036854775805, 1);
INSERT INTO `test` (`b`) VALUES (2);
INSERT INTO `test` (`b`) VALUES (3);
INSERT INTO `test` (`b`) VALUES (4);
INSERT INTO `test` (`b`) VALUES (5);
INSERT INTO `test` (`b`) VALUES (6);
INSERT INTO `test` (`b`) VALUES (7);
INSERT INTO `test` (`b`) VALUES (8);
INSERT INTO `test` (`b`) VALUES (9);

[add2]
Bei UNSIGNED sollte er wohl dann nach 18.446.744.073.709.551.615 auf 0 springen.
SQL-Code:
`a` BIGINT(20) UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY,

query 3. Mai 2007 14:21

Re: mysql autoincrement maximalwert erreicht
 
Ich hab's jetzt mal mit BigInt(20) unsigned ausprobiert. Den ersten Tabelleneintrag hab' ich auf 18446744073709551615 (Maximalwert) gesetzt. Wenn ich danach einen Datensatz einfügen möchte, bei dem er den autoincrement-Wert um eins erhöhen sollte, erhalte ich folgende MySQL-Fehlermeldung: #1062 - Duplicate entry '18446744073709551615' for key 1.

Als nächsten Autoindex zeigt er mir übrigens 9.223.372.036.854.779.000 an, was ich mir überhaupt nicht erklären kann. Den angezeigten nächsten Autoindex kann ich manuell im nächsten Datensatz eintragen, aber MySQL zeigt mir daraufhin immernoch den selben Wert als nächsten Autoindex-Wert an.

Das gewünschte Verhalten wäre, daß MySQL wieder bei 1 anfängt zu zählen. Wie kann ich das am besten erreichen?

mkinzler 3. Mai 2007 14:25

Re: mysql autoincrement maximalwert erreicht
 
Zitat:

Das gewünschte Verhalten wäre, daß MySQL wieder bei 0 anfängt zu zählen.
Kommt aber auf den Fall an, ob das erwünscht ist.

query 3. Mai 2007 14:26

Re: mysql autoincrement maximalwert erreicht
 
@mkinzler: in meinem Fall wäre das erwünscht, oder wenigstens besser als eine Fehlermeldung.

Hab' meine vorheriges posting nochmal verbessert, nicht bei 0, sondern bei 1 soll MySQL wieder anfangen zu zählen. Kann man das evtl. irgendwo in der My.ini einstellen?

Den angezeigten nächsten AutoIndex-Wert, den ich in Posting #3 erwähnt habe, kann man scheinbar ignorieren. Wenn ich als ersten Wert 18446744073709551614 eintrage, zeigt er den genannten nächsten Autoindex-Wert an. Füge ich dann einen neuen Datensatz ein, in dem der Autoincrement-Wert um eins erhöht werden sollte, wird der Wert 18446744073709551615 eingetragen. Beim darauf folgenden Datensatz erhalte ich allerdings immernoch die genannte Fehlermeldung.


Alle Zeitangaben in WEZ +1. Es ist jetzt 14:36 Uhr.

Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz