Mysql
 sql >> Datenbank >  >> RDS >> Mysql

Wie kann man gelöschte Primärschlüssel in MySQL wiederverwenden?

Verwendung:

ALTER TABLE [your table name here] AUTO_INCREMENT = 1

... setzt den auto_increment-Wert auf den nächsten basierend auf dem höchsten vorhandenen Wert in der Tabelle zurück. Das bedeutet, dass es nicht verwendet werden kann, um Lücken von mehr als einem zu korrigieren.

Der einzige Grund dafür wäre kosmetischer Natur - die Datenbank kümmert sich nicht darum, ob Datensätze sequentiell sind, sondern nur darum, dass sie sich konsistent aufeinander beziehen. Es besteht keine Notwendigkeit, die Werte der Datenbank zuliebe zu "korrigieren".

Wenn Sie die id anzeigen Werte an den Benutzer, weshalb Sie möchten, dass sie immer sequentiell sind, dann würde ich empfehlen, einen Ersatzschlüssel hinzuzufügen. Verwenden Sie den Ersatzschlüssel, um ihn dem Benutzer anzuzeigen, sodass die Werte nach Bedarf neu geordnet werden können, die referenzielle Integrität jedoch ansonsten nicht beeinträchtigt wird. Der Ersatzschlüssel wäre in diesem Fall eine Integer-Spalte.