mysql

Reiniciar contador de auto incremento en MySQL

Introducción

En MySQL podemos establecer una columna como autoincremento, es decir, que tenga una columna cuyo valor vaya aumentando en 1 automáticamente cada que ingresa un nuevo dato. Esto está genial, porque podemos utilizar esa columna como un identificador.

Todo muy bien hasta aquí, hasta que por alguna u otra razón necesitamos reiniciar ese contador. Ya que por ejemplo puede que tengamos algunos registros eliminados y entonces habrá “huecos” en nuestra tabla.

También puede darse el caso de que hayamos vaciado nuestra tabla y queremos que el contador comience desde 1.

Para ello es que escribo hoy esa entrada, para reiniciar y establecer al valor mínimo permitido el autoincremento.

Comando y explicación

Si no quieres ver el tutorial completo, la consulta es la siguiente:

ALTER TABLE nombre_de_la_tabla AUTO_INCREMENT = 1;

No te preocupes, el contador se pondrá al valor más bajo que tenga tu tabla. Por ejemplo, supongamos que tienes 10 registros de 100 que había (eliminaste 90 aleatoriamente) por lo que la secuencia del contador puede ir así:

1, 20, 21, 26, 31, 35, 36, 37, 38, 41

Tu autoincremento estará en 100, aunque en realidad el valor más grande que tienes es 41. Si insertas un nuevo registro, su valor será 101, no 42.

Lo que logras con esta consulta es resetear el contador al valor más bajo, que en este caso es 41. Y luego, al insertar el siguiente registro, su valor será 42.

Si quieres ver un ejemplo continúa leyendo…

Ejemplo

Para este ejemplo crearé una tabla de prueba llamada “nombres” que sólo tendrá dos columnas: un auto incremento y el nombre. La definición queda así:

CREATE TABLE nombres(
  rowid BIGINT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY,
  nombre VARCHAR(255) NOT NULL
);

Ahora voy a insertar algunos valores….

INSERT INTO nombres(nombre) 
VALUES 
('Pedro'), 
('Juana'), 
('María'), 
('Roberto'), 
('Clarice');

Hasta ahora, los datos que tengo son estos:

Voy a eliminar los últimos 2 nombres:

DELETE FROM nombres WHERE rowid IN (4, 5);

Y ahora los datos que existen son los siguientes:

Aquí viene la parte crucial de este experimento. Si inserto un nuevo nombre, su rowid será el 6, aunque yo esperaba que fuera el 4. Vamos a insertarlo entonces:

INSERT INTO nombres(nombre) VALUES('José');

Pero al ver los datos, vemos que efectivamente el id que tomó es el 6:

Ahora eliminaré de nuevo ese nombre, es decir, el que tiene el rowid 6:

DELETE FROM nombres WHERE rowid = 6;

Y no insertaré un nuevo nombre justo ahora, sino que reiniciaré el contador:

ALTER TABLE nombres AUTO_INCREMENT = 1;

Ahora sí insertaré un nuevo nombre, cuyo rowid espero que sea 4:

INSERT INTO nombres(nombre) VALUES ('Julián');

Si selecciono los datos, veré que efectivamente el rowid es 4. Y eso comprueba que este método funciona perfectamente

Eso es todo por hoy

Estoy aquí para ayudarte 🤝💻


Estoy aquí para ayudarte en todo lo que necesites. Si requieres alguna modificación en lo presentado en este post, deseas asistencia con tu tarea, proyecto o precisas desarrollar un software a medida, no dudes en contactarme. Estoy comprometido a brindarte el apoyo necesario para que logres tus objetivos. Mi correo es parzibyte(arroba)gmail.com, estoy como@parzibyte en Telegram o en mi página de contacto

No te pierdas ninguno de mis posts 🚀🔔

Suscríbete a mi canal de Telegram para recibir una notificación cuando escriba un nuevo tutorial de programación.
parzibyte

Programador freelancer listo para trabajar contigo. Aplicaciones web, móviles y de escritorio. PHP, Java, Go, Python, JavaScript, Kotlin y más :) https://parzibyte.me/blog/software-creado-por-parzibyte/

Ver comentarios

Entradas recientes

Resetear GOOJPRT PT-210 MTP-II (Impresora térmica)

El día de hoy vamos a ver cómo restablecer la impresora térmica GOOJPRT PT-210 a…

4 semanas hace

Proxy Android para impresora térmica ESC POS

Hoy voy a enseñarte cómo imprimir en una impresora térmica conectada por USB a una…

4 semanas hace

Android – Servidor web con servicio en segundo plano

En este post voy a enseñarte a programar un servidor web en Android asegurándonos de…

4 semanas hace

Cancelar trabajo de impresión con C++

En este post te quiero compartir un código de C++ para listar y cancelar trabajos…

2 meses hace

Copiar bytes de Golang a JavaScript con WebAssembly

Gracias a WebAssembly podemos ejecutar código de otros lenguajes de programación desde el navegador web…

3 meses hace

Imprimir PDF con Ghostscript en Windows de manera programada

Revisando y buscando maneras de imprimir un PDF desde la línea de comandos me encontré…

3 meses hace

Esta web usa cookies.