我正在尝试删除一个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。
答案 0 :(得分:4)
确保没有用户可以连接到您的数据库(超级用户特权,超级用户仍然可以连接):
ALTER DATABASE mydb CONNECTION LIMIT 0;
强制断开与该数据库连接的所有客户端的连接(数据库所有者特权):
SELECT pg_terminate_backend(pid)
FROM pg_stat_activity
WHERE datname = 'mydb';
然后使用您的drop命令删除数据库(数据库所有者特权):
DROP DATABASE mydb;