mysql用like删除表_MySQL删除表

在本教程中,我们将向您展示如何使用MySQL DROP TABLE语句删除数据中存在的表。

MySQL DROP TABLE语句语法

要删除现有表,请使用MySQL DROP TABLE语句。 DROP TABLE的语法如下:

DROP [TEMPORARY] TABLE [IF EXISTS] table_name [, table_name] ...

[RESTRICT | CASCADE]

DROP TABLE语句从数据库中永久删除一个表及其数据。 在MySQL中,也可以使用单个DROP TABLE语句删除多个表,每个表之间用逗号(,)分隔。

TEMPORARY标志指定仅删除临时表。用于以确保不会意外删除非临时表时非常方便。

IF EXISTS添加可帮助防止删除不存在的表。当使用IF EXISTS添加时,MySQL生成一个”提示信息”,可以使用SHOW WARNING语句检索。 重要的是要注意,当在指定删除表的列表中存在不存在的表时,DROP TABLE语句将删除所有现有表并发出错误消息或“提示信息”。

如上所述,DROP TABLE语句仅删除表及其数据。 但是,它不会删除与表关联的特定用户权限。 因此,如果在此之后重新创建了具有相同名称的表,则现有权限将适用于新表,这可能会导致安全风险。

RESTRICT和CASCADE标志为未来版本的MySQL保留。最后但并非最不重要的是,必须具有要删除的表的DROP权限。

MySQL DROP TABLE示例

我们将删除在使用CREATE TABLE语句创建表教程中创建的tasks表。 另外,删除一个不存在的表来练习SHOW WARNING语句。删除tasks表的语句和删除不存在的表nonexistent_table,如下:

DROP TABLE IF EXISTS tasks, nonexistent_table;

如果查看数据库,将看到tasks表已被删除。可以通过使用SHOW WARNING语句来检查MySQL由于不存在的表生成的”提示信息”,如下所示:

SHOW WARNINGS;

执行上面语句,得到以下结果 -

mysql> SHOW WARNINGS;

+-------+------+------------------------------------------+

| Level | Code | Message |

+-------+------+------------------------------------------+

| Note | 1051 | Unknown table 'testdb.nonexistent_table' |

+-------+------+------------------------------------------+

1 row in set

MySQL DROP TABLE WITH LIKE

假设有许多表的名称在数据库中是以字符test开始,我们希望通过使用单个DROP TABLE语句删除所有这些表以节省时间。 不幸的是,MySQL不提供DROP TABLE LIKE语句,可以根据以下模式匹配来删除表:

DROP TABLE LIKE '%pattern%'

但是,有一些解决方法。 我们将在此讨论其中一个,以供您参考。为了演示,我们需要创建一些以字符串test*开头的表。

CREATE TABLE IF NOT EXISTS test1(

id int(11) NOT NULL AUTO_INCREMENT,

PRIMARY KEY(id)

);

CREATE TABLE IF NOT EXISTS test2 LIKE test1;

CREATE TABLE IF NOT EXISTS test3 LIKE test1;

CREATE TABLE IF NOT EXISTS test4 LIKE test1;

使用相同的表结构创建了名为:test1,test2,test3和test4的四个表。假设您想要一次删除所有字符串test*开头的表,可以按照以下步骤:

首先,声明接受数据库模式的两个变量和要与表进行匹配的模式:

-- set table schema and pattern matching for tables

SET @schema = 'testdb';

SET @pattern = 'test%';

接下来,需要构建动态DROP TABLE语句:

-- build dynamic sql (DROP TABLE tbl1, tbl2...;)

SELECT CONCAT('DROP TABLE ',GROUP_CONCAT(CONCAT(@schema,'.',table_name)),';')

INTO @droplike

FROM information_schema.tables

WHERE @schema = database()

AND table_name LIKE @pattern;

基本上,查询指示MySQL转到information_schema表,其中包含所有数据库中所有表的数据,并将与模式@schema(testdb)中的所有表连接到前缀DROP TABLE。GROUP_CONCAT函数创建一个逗号分隔的表列表。

然后,可以显示动态SQL以验证其是否正常工作:

-- display the dynamic sql statement

SELECT @droplike;

执行上面语句,得到以下结果 -

mysql> SELECT @droplike;

+-----------------------------------------------------------------+

| @droplike |

+-----------------------------------------------------------------+

| DROP TABLE testdb.test1,testdb.test2,testdb.test3,testdb.test4; |

+-----------------------------------------------------------------+

1 row in set

可以看到它按预期工作。

之后,可以使用MySQL中的prepare语句执行语句如下:

-- execute dynamic sql

PREPARE stmt FROM @droplike;

EXECUTE stmt;

DEALLOCATE PREPARE stmt;

有关MySQL准备语句的更多信息,请查看MySQL准备语句教程。

把它们放在一起,如下所示 -

-- set table schema and pattern matching for tables

SET @schema = 'testdb';

SET @pattern = 'test%';

-- build dynamic sql (DROP TABLE tbl1, tbl2...;)

SELECT CONCAT('DROP TABLE ',GROUP_CONCAT(CONCAT(@schema,'.',table_name)),';')

INTO @droplike

FROM information_schema.tables

WHERE @schema = database()

AND table_name LIKE @pattern;

-- display the dynamic sql statement

SELECT @droplike;

-- execute dynamic sql

PREPARE stmt FROM @dropcmd;

EXECUTE stmt;

DEALLOCATE PREPARE stmt;

因此,如果要删除在数据库中具有特定模式的多个表,则只需使用上面的脚本来节省时间。 所有您需要做的是在存储过程,并重新使用此存储过程。

在本教程中,我们向您展示了如何使用DROP TABLE语句来删除特定数据库中的现有表。还讨论了一种解决方法,允许使用DROP TABLE语句根据模式匹配删除表。

¥ 我要打赏

纠错/补充

收藏

加QQ群啦,易百教程官方技术学习群

注意:建议每个人选自己的技术方向加群,同一个QQ最多限加 3 个群。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值