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

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';

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


当前回答

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

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

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

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

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

在我的例子中是问题

其他回答

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

ps -ef | grep postgres

使用此命令终止进程

sudo kill -9 PID

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

SELECT * FROM pg_stat_activity WHERE datname = 'TARGET_DB';

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

就这么简单

sudo service postgresql restart

停止正在运行的应用程序。(在Eclipse中) 在你再试一次之后。

虽然我发现在其他场合获得最高票数的两个答案很有用,但今天,解决这个问题的最简单方法是意识到PyCharm可能会保持会话打开,如果我在PyCharm中单击“停止”,这可能会有所帮助。在浏览器中打开pgAdmin4后,我这样做了,几乎立即看到数据库会话统计数据降为0,此时我可以删除数据库。