使用Python删除不存在的表时,如何避免出错?


可能会出现这种情况:您可能正在删除数据库中实际上不存在的表。在执行从数据库删除表的命令时,我们可能会给出数据库中不存在的表的错误名称。另一种可能性是,您正在删除的表已经被其他有权访问数据库的人员删除了。在这种情况下,执行命令时会出错,因为您要删除的表不存在。

可以通过检查表是否存在然后再删除它来避免此错误。如果表不存在,则删除该表的命令将不会执行,也不会出现任何错误。

IF EXISTS 语句用于验证我们想要删除的表是否存在。

语法

DROP TABLE IF EXISTS table_name

只有在表存在的情况下,上述语句才会执行删除表的运算,否则它不会执行任何操作,从而防止出错。

使用Python中的MySQL检查数据库中是否存在表后删除表的步骤

  • 导入MySQL连接器

  • 使用connect()方法建立与连接器的连接

  • 使用cursor()方法创建游标对象

  • 使用合适的MySQL语句创建查询

  • 使用execute()方法执行SQL查询

  • 关闭连接

示例

假设,我们需要从数据库中删除一个表,但在删除之前,我们需要检查它是否存在。

import mysql.connector
db=mysql.connector.connect(host="your host", user="your username", password="your
password",database="database_name")

cursor=db.cursor()

query="DROP TABLE IF EXISTS Employees "
cursor.execute(query)
print("TABLE DROPED..")

db.close()

如果表“Employees”存在,则上述代码会将其从数据库中删除。否则,如果表不存在,则不会出现任何错误。

输出

TABLE DROPED..

更新于:2021年6月10日

588 次浏览

开启您的职业生涯

完成课程获得认证

开始学习
广告