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

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

你会看到:

501 1445 3645 0 12:05AM 0:00.03 postgres: sasha dbname (本地)闲置

第三个数字(3645)是PID。

你可以删除这个

sudo kill -9 3645

然后启动PostgreSQL连接。

手动启动:

pg_ctl -D /usr/local/var/postgres start

其他回答

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

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

选择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);

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

每当我尝试删除数据库时,我得到:

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

首先你需要撤销

REVOKE CONNECT ON DATABASE TARGET_DB FROM public;

然后使用:

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

它肯定会起作用。

您需要确定的是使用DB的服务没有运行。

遇到同样的问题,运行一些Java应用程序,上面的选项都不起作用,甚至不能重新启动。

使用DB运行ps aux终止主服务。

kill -9 PID 或者如果应用程序作为服务运行,请确保为您的操作系统运行service stop cmd。

在此之后,删除表的默认方式将完美地工作。

在我的例子中是问题

解决方案: 1. 关闭Pg服务器 2. 它将断开所有活动连接 3.重启Pg服务器 4. 试试你的命令

在Postgresql 13中更新

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

DROP DATABASE db_name WITH (FORCE)

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

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