En este post te mostraré cómo agregar una columna a tabla de SQLite usando la sentencia ALTER TABLE
en SQLite incluso si ya hay datos en la misma.
Agregar columna a tabla de SQLite: sintaxis
La sintaxis es:
ALTER TABLE tu_tabla ADD definición_columna;
En este caso la definición es el tipo de dato así como el nombre de la columna. Si agregas NOT NULL
recuerda agregar un valor DEFAULT
.
Ejemplo para añadir columna en SQLite
Comienzo definiendo una tabla de personas:
CREATE TABLE IF NOT EXISTS personas(
nombre TEXT NOT NULL
);
Se insertan y consultan datos:
INSERT INTO personas(nombre) VALUES ("Luis"), ("María");
SELECT * FROM personas;
Ahora quiero agregar la columna edad
así que ejecuto:
ALTER TABLE personas ADD edad INTEGER NOT NULL DEFAULT 0;
Estoy definiendo que no puede ser nula, por eso debo proveer el valor por defecto. En caso de que tú quieras permitir que sea nula, no debes especificar el valor por defecto.
Después de eso ya se pueden agregar datos tomando en cuenta la columna recién agregada:
INSERT INTO personas(nombre, edad) VALUES ("Reyna", 63);
Al consultar, aparecerán todos los datos:
Como se puede observar, la otra columna tiene el valor por defecto pero ya hemos agregado la columna de manera exitosa.
Recuerda que el valor por defecto debe ir acorde a tu campo o mejor dicho a su tipo de dato, por ejemplo, si fuera una cadena, puedes especificar DEFAULT '';