每当我尝试删除数据库,我得到以下错误:

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

当我使用:

SELECT pg_terminate_backend(pg_stat_activity.pid)
FROM pg_stat_activity
WHERE pg_stat_activity.datname = 'TARGET_DB';

我终止了来自该数据库的连接,但如果我试图在此之后删除数据库,则有人以某种方式自动连接到该数据库并给出此错误。那是什么? 除了我,没人用这个数据库。


当前回答

我找到了这个问题的解决方案,尝试在终端运行这个命令

ps -ef | grep postgres

使用此命令终止进程

sudo kill -9 PID

其他回答

你可以阻止未来连接:

REVOKE CONNECT ON DATABASE thedb FROM public;

(可能还有其他用户/角色;查看psql中的\l+

然后你可以终止所有到这个db的连接,除了你自己的:

SELECT pid, pg_terminate_backend(pid) 
FROM pg_stat_activity 
WHERE datname = current_database() AND pid <> pg_backend_pid();

在旧版本中,pid被称为procpid,所以你必须处理这个问题。

既然您已经撤销了CONNECT权限,那么试图自动连接的任何程序都不能再这样做了。

现在可以删除DB了。

如果您使用超级用户连接进行正常操作,这将不起作用,但如果您正在这样做,则需要首先解决这个问题。


删除数据库后,如果再次创建数据库,可以执行以下命令恢复访问

GRANT CONNECT ON DATABASE thedb TO public;

Postgresql12

流行的回答对我没有帮助。

对我来说一个不明显的解决方案:如果使用kafka/rabbit,在DROP TABLE之前禁用管理器

sudo service supervisor stop

在我看来,有一些空闲的查询在后台运行。

首先尝试显示正在运行的查询

选择pid,年龄(clock_timestamp(), query_start),用户名,查询 从pg_stat_activity WHERE query != '<IDLE>' AND query NOT ILIKE '%pg_stat_activity%' ORDER BY query_start desc;

检查它们是否引用了有问题的数据库,或者您可以杀死所有它们或使用 Pid从选择结果)

选择pg_terminate_backend (procpid);

注意:终止一个选择查询不会造成任何不良影响

只需检查连接是什么,它来自哪里。你可以看到这些:

SELECT * FROM pg_stat_activity WHERE datname = 'TARGET_DB';

也许这是你们之间的联系?

在Postgresql 13中更新

您可以使用此命令强制删除数据库,从而断开连接到它的每个用户/应用程序。

DROP DATABASE db_name WITH (FORCE)

你可以查看说明书了解更多信息。

力, 尝试终止到目标数据库的所有现有连接。如果目标数据库中存在准备好的事务、活动逻辑复制插槽或订阅,则它不会终止。