为什么我不能删除Postgres数据库

时间:2020-09-23 08:23:11

标签: sql postgresql drop-database

我正在尝试删除一个postgres数据库。但是我总是得到一个

还有1个使用该数据库的会话

错误。

我尝试使用此命令停止所有会话

select pg_terminate_backend(pid) from pg_stat_activity where datname='my_database';

这是结果

pg_terminate_backend
----------------------
(0 rows)

然后我使用了该命令

DROP DATABASE my_database;

这是整个错误消息

ERROR:  database "my_database" is being accessed by other users
DETAIL:  There is 1 other session using the database.

我正在使用postgres 12。

1 个答案:

答案 0 :(得分:4)

  1. 确保没有用户可以连接到您的数据库(超级用户特权,超级用户仍然可以连接):

    ALTER DATABASE mydb CONNECTION LIMIT 0; 
    
  2. 强制断开与该数据库连接的所有客户端的连接(数据库所有者特权):

    SELECT pg_terminate_backend(pid)
    FROM pg_stat_activity
    WHERE datname = 'mydb';
    
  3. 然后使用您的drop命令删除数据库(数据库所有者特权):

    DROP DATABASE mydb;
    
相关问题