MySQL删除数据库(DROP DATABASE语句)

在 MySQL 中,当需要删除已创建的数据库时,可以使用
DROP DATABASE
DROP SCHEMA 语句。其语法格式为:

DROP DATABASE [ IF EXISTS ] <数据库名>

语法说明如下:

  • <数据库名>:指定要删除的数据库名。
  • IF EXISTS:用于防止当数据库不存在时发生错误。
  • DROP DATABASE:删除数据库中的所有表格并同时删除数据库。使用此语句时要非常小心,以免错误删除。如果要使用 DROP DATABASE,需要获得数据库 DROP 权限。

注意:MySQL 安装后,系统会自动创建名为 information_schema 和 mysql 的两个系统数据库,系统数据库存放一些和数据库相关的信息,如果删除了这两个数据库,MySQL 将不能正常工作。

MySQL删除数据库实例

下面在 MySQL 中创建一个测试数据库 test_db_del。

  mysql> CREATE DATABASE test_db_del;  Query OK, 1 row affected (0.08 sec)  mysql> SHOW DATABASES;  +--------------------+  | Database           |  +--------------------+  | information_schema |  | mysql              |  | performance_schema |  | sakila             |  | sys                |  | test_db            |  | test_db_char       |  | test_db_del        |  | world              |  +--------------------+  9 rows in set (0.00 sec)

使用命令行工具将数据库 test_db_del 从数据库列表中删除,输入的 SQL 语句与执行结果如下所示:

  mysql> DROP DATABASE test_db_del;  Query OK, 0 rows affected (0.57 sec)  mysql> SHOW DATABASES;  +--------------------+  | Database           |  +--------------------+  | information_schema |  | mysql              |  | performance_schema |  | sakila             |  | sys                |  | test_db            |  | test_db_char       |  | world              |  +--------------------+  8 rows in set (0.00 sec) 

此时数据库 test_db_del 不存在。再次执行相同的命令,直接使用 DROP DATABASE test_db_del,系统会报错,如下所示:

  mysql> DROP DATABASE test_db_del;  ERROR 1008 (HY000): Can't drop database 'test_db_del'; database doesn't exist

如果使用IF EXISTS从句,可以防止系统报此类错误,如下所示:

  mysql> DROP DATABASE IF EXISTS test_db_del;  Query OK, 0 rows affected, 1 warning (0.00 sec)

版权声明:
作者:自由看
链接:https://www.ziyoukan.cn/?p=2571
来源:自由看
文章版权归作者所有,未经允许请勿转载。

THE END
分享
二维码
< <上一篇
下一篇>>