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

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

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


当前回答

这意味着另一个用户正在访问数据库。简单地重启PostgreSQL。这个命令就可以了

root@kalilinux:~#sudo service postgresql restart

然后尝试删除数据库:

postgres=# drop database test_database;

这样就可以了。

其他回答

如果在IntelliJ中遇到此错误,请确保通过单击下面所示的按钮关闭所有窗口中的连接

在Postgresql 13中更新

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

DROP DATABASE db_name WITH (FORCE)

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

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

如果您正在使用docker运行postgresql服务器,请重新启动容器。

这意味着另一个用户正在访问数据库。简单地重启PostgreSQL。这个命令就可以了

root@kalilinux:~#sudo service postgresql restart

然后尝试删除数据库:

postgres=# drop database test_database;

这样就可以了。

在macOS中尝试通过控制台使用以下命令重新启动postgresql数据库:

brew services restart postgresql