MySQL 入门教程
  • 教程目录
  • 第一章 基础教程
    • 第一节 入门
      • 1.1 安装
      • 1.2 示例数据库
    • 第二节 查询数据
      • 2.1 SELECT 语句
      • 2.2 SELECT DISTINCT 语句
    • 第三节 过滤数据
      • 3.1 WHERE 子句
      • 3.2 AND 运算符
      • 3.3 OR 运算符
      • 3.4 IN 运算符
      • 3.5 BETWEEN 运算符
      • 3.6 LIKE 运算符
      • 3.7 LIMIT 子句
      • 3.8 IS NULL 运算符
    • 第四节 数据排序
      • 4.1 ORDER BY 子句
      • 4.1 自然排序
    • 第五节 连接表
      • 5.1 别名
      • 5.2 INNER JOIN
      • 5.3 LEFT JOIN
      • 5.4 自连接
      • 5.5 CROSS JOIN
    • 第六节 分组数据
      • 6.1 GROUP BY子句
      • 6.2 HAVING 子句
    • 第七节 子查询,派生表和通用表达式
      • 7.1 子查询
      • 7.2 派生表
      • 7.3 公共表表达式
      • 7.4 递归 CTE
    • 第八节 集合操作符
      • 8.1 UNION 和 UNION ALL
      • 8.2 INTERSECT 模拟
    • 第九节 修改数据
      • 9.1 INSERT 语句
      • 9.2 INSERT IGNORE
      • 9.3 UPDATE 语句
      • 9.4 UPDATE JOIN 语句
      • 9.5 DELETE
      • 9.6 ON DELETE CASCADE.
      • 9.7 DELETE JOIN
      • 9.8 REPLACE 语句
      • 9.9 PREPARE 语句
    • 第十节 事务
      • 10.1 事务介绍
      • 10.2 表锁定
    • 第十一节 管理数据库和表
      • 11.1 数据库管理
      • 11.2 MySQL 表类型
      • 11.3 CREATE TABLE
      • 11.4 序列
      • 11.5 ALTER TABLE
      • 11.6 重命名表
      • 11.7 从表中删除列
      • 11.8 向表中添加新列
      • 11.9 删除表
      • 11.10 临时表
      • 11.11 TRUNCATE TABLE
    • 第十二节 索引
      • 12.1 管理索引
      • 12.1 UNIQUE 索引
    • 第十三节 数据类型
      • 13.1 INT
      • 13.2 DECIMAL
      • 13.3 BIT
      • 13.4 BOOLEAN
      • 13.5 CHAR
      • 13.6 VARCHAR
      • 13.7 TEXT
      • 13.8 DATE
      • 13.9 TIME
      • 13.10 DATETIME
      • 13.11 TIMESTAMP
      • 13.12 JSON
      • 13.13 ENUM
    • 第十四节 约束
      • 14.1 NOT NULL 约束
      • 14.2 主键约束
      • 14.2 外键约束
      • 14.4 UNIQUE 约束
      • 14.5 CHECK 约束
    • 第十五节 全球化
      • 15.1 字符集
      • 15.2 校对规则
    • 第十六节 导入和导出
      • 16.1 导入 CSV 文件
      • 16.2 导出为 CSV
  • 第二章 技巧
    • CTE 简介
    • 递归 CTE
    • 邻接列表模型和层次结构
    • 获取行数
    • 比较表
    • 找重复值
    • 删除重复行
    • UUID 和主键
    • 复制表数据
    • 变量
    • 生成列
    • 连续行比较
    • 更改存储引擎
    • 基于正则表达式的搜索
    • row_number 模拟
    • 随机选择记录
    • 选择第 n 个最高纪录
    • 重置自动增量值
    • MariaDB 与 MySQL 比较
    • 间隔
    • NULL 详细和应用
    • 获取今天的日期
    • 将NULL值映射到有意义的值
    • 注释
  • 第三章 存储过程
    • 简介
    • 入门
    • 变量
    • 参数
    • 返回多个值
    • IF语句
    • CASE语句
    • IF和CASE语句的技巧
    • 循环
    • 游标
    • 列出存储过程
    • 错误处理
    • SIGNAL 和 ESIGNAL 语句
    • 存储函数
  • 第四章 触发器
    • 实现
    • 创建
    • 创建多个触发器
    • 管理
    • 计划事件
    • 修改事件
  • 第五章 视图
    • 简介
    • 实现和限制
    • 创建
    • 可更新视图
    • 确保视图一致性
    • 检查选项子句
    • 管理
  • 第六章 全文搜索
    • 简介
    • 定义索引
    • 自然语言全文搜索
    • 布尔全文搜索
    • 查询扩展
    • ngram全文解析器
  • 第七章 函数
  • 第八章 管理
    • 访问控制系统入门
    • 创建用户
    • 授予权限
    • 撤销权限
    • 角色管理
    • 删除用户
    • 维护数据库表
    • 备份数据库
    • 列出数据库
    • 列出表
    • 列出表的列
    • 列出用户
Powered by GitBook
On this page
  • MySQL DROP TABLE语句语法
  • MySQL DROP TABLE示例
  • MySQL DROP TABLE WITH LIKE

Was this helpful?

  1. 第一章 基础教程
  2. 第十一节 管理数据库和表

11.9 删除表

Previous11.8 向表中添加新列Next11.10 临时表

Last updated 5 years ago

Was this helpful?

在本教程中,我们将向您展示如何使用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;

然后,可以显示动态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

可以看到它按预期工作。

-- execute dynamic sql
PREPARE stmt FROM @droplike;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;

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

-- 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语句根据模式匹配删除表。

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

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

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

因此,如果要删除在数据库中具有特定模式的多个表,则只需使用上面的脚本来节省时间。 所有您需要做的是在@pattern和@schema变量中替换模式和数据库模式。 如果您经常需要处理此任务,则可以始终基于脚本开发,并重新使用此存储过程。

临时表
GROUP_CONCAT
prepare语句
MySQL准备语句教程
存储过程