English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية

Comando ALTER TABLE en SQLite

La orden ALTER TABLE de SQLite puede modificar tablas existentes sin necesidad de realizar un volcado completo de datos y recargarlos. Puede usar la sentencia ALTER TABLE para renombrar tablas y para agregar otras columnas a tablas existentes.

Además de renombrar tablas y agregar columnas a tablas existentes, la orden ALTER TABLE de SQLite no admite otras operaciones.

Sintaxis

A continuación se muestraALTER TABLELa sintaxis básica para renombrar una tabla existente.

ALTER TABLE database_name.table_name RENAME TO new_table_name;

A continuación se muestraALTER TABLELa sintaxis básica para agregar una nueva columna a una tabla existente.

ALTER TABLE database_name.table_name ADD COLUMN column_def...;

Ejemplo en línea

La tabla COMPANY con los siguientes registros-

ID                                   NOMBRE                                       EDAD                                       DIRECCIÓN                               SALARIO
----------  ----------  ----------  ----------  ----------
1           Paul        32          California  20000.0
2           Allen       25          Texas       15000.0
3           Teddy       23          Norway      20000.0
4           Mark        25          Rich-Mond   65000.0
5           David       27          Texas       85000.0
6           Kim         22          South-Hall  45000.0
7           James       24          Houston     10000.0

Ahora, intentemos renombrar la tabla utilizando la sentencia ALTER TABLE, como se muestra a continuación:

sqlite> ALTER TABLE COMPANY RENAME TO OLD_COMPANY;

La sentencia SQLite anterior renombrará la tabla COMPANY a OLD_COMPANY. Ahora, intentemos agregar una nueva columna a la tabla OLD_COMPANY, como se muestra a continuación:

sqlite> ALTER TABLE OLD_COMPANY ADD COLUMN SEX char(1);

La empresa ahora ha cambiado, a continuación se muestra la salida de la sentencia SELECT.

ID                         NOMBRE                         EDAD                         DIRECCIÓN                     SALARIO                     SEXO
----------  ----------  ----------  ----------  ----------  ---
1           Paul        32          California  20000.0
2           Allen       25          Texas       15000.0
3           Teddy       23          Norway      20000.0
4           Mark        25          Rich-Mond   65000.0
5           David       27          Texas       85000.0
6           Kim         22          South-Hall  45000.0
7           James       24          Houston     10000.0

Se debe tener en cuenta que las columnas recién añadidas están llenas de valores NULL.