Python MySQL - Drop Table

Puede eliminar una tabla completa utilizando el DROP TABLEdeclaración. Solo necesita especificar el nombre de la tabla que necesita eliminar.

Sintaxis

A continuación se muestra la sintaxis de la declaración DROP TABLE en MySQL:

DROP TABLE table_name;

Ejemplo

Antes de eliminar una tabla, obtenga la lista de tablas utilizando la instrucción SHOW TABLES de la siguiente manera:

mysql> SHOW TABLES;
+-----------------+
| Tables_in_mydb  |
+-----------------+
| contact         |
| cricketers_data |
| employee        |
| sample          |
| tutorials       |
+-----------------+
5 rows in set (0.00 sec)

La siguiente declaración elimina completamente la tabla llamada muestra de la base de datos:

mysql> DROP TABLE sample;
Query OK, 0 rows affected (0.29 sec)

Dado que hemos eliminado la tabla llamada muestra de MySQL, si vuelve a obtener la lista de tablas, no encontrará la muestra del nombre de la tabla en ella.

mysql> SHOW TABLES;
+-----------------+
| Tables_in_mydb  |
+-----------------+
| contact         |
| cricketers_data |
| employee        |
| tutorials       |
+-----------------+
4 rows in set (0.00 sec)

Eliminar una tabla usando Python

Puede eliminar una tabla siempre que lo necesite, utilizando la declaración DROP de MYSQL, pero debe tener mucho cuidado al eliminar cualquier tabla existente porque los datos perdidos no se recuperarán después de eliminar una tabla.

Para eliminar una tabla de una base de datos MYSQL usando python, invoque el execute() en el objeto cursor y pasarle la sentencia drop como parámetro.

Ejemplo

La siguiente tabla quita una tabla llamada EMPLEADO de la base de datos.

import mysql.connector

#establishing the connection conn = mysql.connector.connect(
   user='root', password='password', host='127.0.0.1', database='mydb'
)

#Creating a cursor object using the cursor() method 
cursor = conn.cursor()

#Retrieving the list of tables print("List of tables in the database: ") 
   cursor.execute("SHOW Tables") print(cursor.fetchall())

#Doping EMPLOYEE table if already exists cursor.execute
   ("DROP TABLE EMPLOYEE") print("Table dropped... ")

#Retrieving the list of tables print(
   "List of tables after dropping the EMPLOYEE table: ") 
   cursor.execute("SHOW Tables") print(cursor.fetchall())

#Closing the connection conn.close()

Salida

List of tables in the database:
[('employee',), ('employeedata',), ('sample',), ('tutorials',)]
Table dropped...
List of tables after dropping the EMPLOYEE table:
[('employeedata',), ('sample',), ('tutorials',)]

Drop table solo si existe

Si intenta eliminar una tabla que no existe en la base de datos, se produce un error como:

mysql.connector.errors.ProgrammingError: 1051 (42S02): 
   Unknown table 'mydb.employee'

Puede evitar este error verificando si la tabla existe antes de eliminarla, agregando IF EXISTS a la instrucción DELETE.

import mysql.connector

#establishing the connection
conn = mysql.connector.connect(
   user='root', password='password', host='127.0.0.1', database='mydb')

#Creating a cursor object using the cursor() method
cursor = conn.cursor()

#Retrieving the list of tables
print("List of tables in the database: ")
cursor.execute("SHOW Tables")
print(cursor.fetchall())

#Doping EMPLOYEE table if already exists
cursor.execute("DROP TABLE IF EXISTS EMPLOYEE")
print("Table dropped... ")

#Retrieving the list of tables
print("List of tables after dropping the EMPLOYEE table: ")
cursor.execute("SHOW Tables")
print(cursor.fetchall())

#Closing the connection
conn.close()

Salida

List of tables in the database:
[('employeedata',), ('sample',), ('tutorials',)]
Table dropped...
List of tables after dropping the EMPLOYEE table:
[('employeedata',), ('sample',),
('tutorials',)]