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


         当数据库不再使用时应该将其删除,以确保数据库存储空间中存放的是有效数据。删除数据库是将已经存在的数据库从磁盘空间上清除,清除之后,数据库中的所有数据也将一同被删除。


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


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


        语法说明:


<数据库名>:指定要删除的数据库名。


IF EXISTS:                用于防止当数据库不存在时发生错误。


DROP DATABASE:   删除数据库中的所有表格并同时删除数据库。使用此语句时要小心,以免错误删除。使用 DROP DATABASE,需要数据库 DROP 权限。


注意:MySQL 安装后,系统会自动创建名为 information_schema 和 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_char                     
| test_db_del                  
+--------------------+
8 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_char                     
+--------------------+
7 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)


          使用 DROP DATABASE 命令时要非常谨慎,在执行该命令后,MySQL 不会给出任何提示确认信息。DROP DATABASE 删除数据库后,数据库中存储的所有数据表和数据也将一同被删除,而且不能恢复。因此最好在删除数据库之前先将数据库进行备份。备份数据库的方法会在教程后面进行讲解。


更新时间: 2023-06-16 Tag:software-note
相关文章
Top