数据库命令行或者管理工具中执行删除数据库的命令,

DROP DATABASE testdb;

的时候,可能会提示:

ERROR:  database "testdb" is being accessed by other users
DETAIL: There are other sessions using the database.

这个意思是说,删除数据库失败,因为这里还有3个链接连接到该数据库上,PostgreSQL在有进程连接到数据库时,对应的数据库是不运行被删除的。

那么怎么办呢?
解决方式:断开连接到这个数据库上的所有链接,再删除数据库。怎么断开呢?在PostgreSQL 9.2 及以上版本,执行下面的语句:

SELECT pg_terminate_backend(pg_stat_activity.pid)
FROM pg_stat_activity
WHERE datname='testdb' AND pid<>pg_backend_pid();
--- 注:testdb 替换成自己的数据库

执行上面的语句之后,在执行DROP操作,就可以删除数据库了。

上面语句说明:
pg_terminate_backend:用来终止与数据库的连接的进程id的函数。
pg_stat_activity:是一个系统表,用于存储服务进程的属性和状态。
pg_backend_pid():是一个系统函数,获取附加到当前会话的服务器进程的ID。

最新文章

  1. 我的屌丝giser成长记-工作篇之A公司
  2. FMX保存JPG格式的Stream
  3. 高斯过程(gaussian process)
  4. linux系统下根据端口查看进程
  5. Java_类文件及加载机制
  6. python_way day16 DOM
  7. 斜率dp cdq 分治
  8. httpClient多线程请求
  9. 仿36氪(iOS版附源代码)
  10. SQL SERVER 2008R2sp1配置Database Mail –用SQL 数据库发邮件
  11. C# 6.0 (C# vNext) 的新功能:Expression Bodied Functions and Properties
  12. Android Studio设置快捷键和背景
  13. js 中 new fn与new fn()的区别
  14. POJ 1741 Tree(树的点分治,入门题)
  15. mysql_config not found和error: command &#39;gcc&#39; failed with exit status 1
  16. ionic3 git 提交报错
  17. Django之Models(二)
  18. spring boot 随手记
  19. Postfix 邮件服务 - PostfixAdmin
  20. 一、I/O操作(缓存流,数据流,对象流)

热门文章

  1. [Ionic] Error: No provider for Http! Error: No provider for Http!
  2. final,static,abstract
  3. Python19/1/11--标签与过滤器/Django模块导入继承/静态文件配置
  4. python_flask项目(BBS)_01
  5. php中出现乱码
  6. Xaml引用图片路径的方式
  7. Exp5MSF基础应用——20164325王晓蕊
  8. 6-使用requests库封装类处理get/post请求
  9. Charles 学习笔记
  10. 中间件 activeMQ Jms Java Demo