更新时间:2022-07-29 GMT+08:00
DROP DATABASE
功能描述
删除一个数据库。
注意事项
- 只有数据库所有者有权限执行DROP DATABASE命令,系统管理员默认拥有此权限。
- 不能对系统默认安装的三个数据库(postgres、TEMPLATE0和TEMPLATE1)执行删除操作,系统做了保护。如果想查看当前服务中有哪几个数据库,可以用gsql的\l命令查看。
- 如果有用户正在与要删除的数据库连接,则删除操作失败。如果要查看当前存在哪些数据库连接,可以通过视图v$session查看。
- 不能在事务块中执行DROP DATABASE命令。
- 如果执行DROP DATABASE失败,事务回滚,需要再次执行一次DROP DATABASE IF EXISTS。
- DROP DATABASE一旦执行将无法撤销,请谨慎使用。
- DROP DATABASE若提示database is being accessed by other users类错误,可能原因为CLEAN CONNECTION过程存在线程无法及时响应信号,出现连接清理不完全的情况,需要再次执行CLEAN CONNECTION。
语法格式
1 |
DROP DATABASE [ IF EXISTS ] database_name;
|
参数说明
- IF EXISTS
如果指定的数据库不存在,则发出一个notice而不是抛出一个错误。
- database_name
要删除的数据库名称。
取值范围:字符串,已存在的数据库名称。
示例
删除名称为music的数据库:
1 |
DROP DATABASE music;
|
父主题: DDL语法