postgresql查看死锁及解决方法

不点 阅读:1069 2020-10-03 16:28:41 评论:0

 

  • 检索出死锁进程的ID

  SELECT * FROM pg_stat_activity WHERE datname='数据库名' and waiting='t';
  找到对用的pid列的值
  或
  select oid from pg_class where relname='可能锁表了的表' --oid是每个表隐藏的id
  select pid from pg_locks where relation='上面查出的oid'

  • 将进程杀掉

  select pg_cancel_backend("死锁那条数据的pid值");
  运行完后,再次刷新这个表,sql就可顺利执行。

 

标签:数据库
声明

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

关注我们

一个IT知识分享的公众号