当数据库不再使用时应该将其删除,以确保数据库存储空间中存放的是有效数据。删除数据库是将已经存在的数据库从磁盘空间上清除,清除之后,数据库中的所有数据也将一同被删除。
删除数据库
在 MySQL中,当需要删除已创建的数据库时,可以使用 DROP DATABASE 语句。其语法格式为:
DROP DATABASE [ IF EXISTS ] <数据库名>
语法说明如下:
注意:MySQL 安装后MySQL 删除数据库,系统会自动创建名为 information_schema 和 mysql 的两个系统数据库,系统数据库存放一些和数据库相关的信息,如果删除了这两个数据库,MySQL 将不能正常工作。
实例
下面在 MySQL 中创建一个测试数据库 test_db_del 并 show 查看。
mysql> CREATE DATABASE test_db_del;
Query OK, 1 row affected (0.01 sec)
mysql> SHOW DATABASES;
+--------------------+
| Database |
+--------------------+
| information_schema |
| db_test |
| db_test_db |
| mysql |
| performance_schema |
| sys |
| test001 |
| test002 |
| test_create |
| test_create_char |
| test_db |
| test_db_d |
| test_db_ddd |
| test_db_del |
+--------------------+
14 rows in set (0.00 sec)
使用命令行工具将数据库 test_db_del 从数据库列表中删除并 show 查看
mysql> DROP DATABASE test_db_del;
Query OK, 0 rows affected (0.00 sec)
mysql> SHOW DATABASES LIKE 'test_db_del';
Empty set (0.00 sec)
mysql> SHOW DATABASES;
+--------------------+
| Database |
+--------------------+
| information_schema |
| db_test |
| db_test_db |
| mysql |
| performance_schema |
| sys |
| test001 |
| test002 |
| test_create |
| test_create_char |
| test_db |
| test_db_d |
| test_db_ddd |
+--------------------+
13 rows in set (0.01 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)
所以创建和删除数据库的时候使用 if not exists 和 if exists 是个好的习惯
使用 DROP DATABASE 命令时要非常谨慎,在执行该命令后,MySQL 不会给出任何提示确认信息。DROP DATABASE 删除数据库后,数据库中存储的所有数据表和数据也将一同被删除,而且不能恢复。因此最好在删除数据库之前先将数据库进行备份。
(编辑:威海站长网)
【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!
|