数据库不再使用时,必须及时清理,否则不仅占用存储空间,还容易造成混淆——一旦误连错误数据库,后果可能非常严重。所谓删除数据库,就是从磁盘上彻底移除该库,连同其中的所有数据表、视图等全部清除。在 MySQL 中执行此操作,主要依靠 DROP DATABASE 语句,语法极其简洁:
DROP DATABASE [ IF EXISTS ] 数据库名;
以下几点请务必留意:
- 数据库名:即你要删除的目标数据库名称。
- IF EXISTS:加上该从句后,即使数据库不存在也不会报错,仅返回一个警告。若不添加,当库不存在时,系统会直接抛出错误。
- 权限:执行
DROP DATABASE需要具备目标数据库的 DROP 权限,并非所有用户都能随意执行删除操作。
此外需要特别提醒:MySQL 安装完成后默认包含两个系统数据库——information_schema 和 mysql,它们保存着数据库元信息、用户权限等关键数据。这两个库绝对不可删除,否则 MySQL 将无法正常运行,后果自负。
理论讲得再多,不如亲手操作一遍。下面直接进行演示。
首先查看当前所有数据库:
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 这个库很可能是测试用的,我们就以它为例进行删除:
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)
如果此时手误重复执行相同的删除命令(未加 IF EXISTS),系统会立即报错:
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 不会弹出确认框,也不会询问“你确定吗”。一旦执行,数据库及其所有表和记录将彻底消失,想要恢复只有依靠事前备份。因此,**删除之前务必做好完整备份**。至于如何备份,属于另一项重要技能,我们后续再详细讲解。
