解决 postgreSQL truncate table过慢无响应问题

在 postgreSQL 清空表 TRUNCATE TABLE table_name RESTART IDENTITY RESTRICT;的时候,突然发生等了很久都没反应的问题,忧郁之。

查了一下,一般遇到表操作过慢或者无响应之类的问题,可以像对操作系统一样kill掉process就好了。

在本例中, 首先使用以下语句列出相关PID

SELECT *  
  FROM pg_locks l
  JOIN pg_class t ON l.relation = t.oid AND t.relkind = 'r'
 WHERE t.relname = 'table_name';

来查看其他别的sessions是不是占用了这张表,结果大概长下面这样

  pid  | relname 
-------+---------
 31061 | table_name
 31390 | table_name
(2 rows)

然后把它们kill掉就好了,执行类似以下语句:

SELECT pg_cancel_backend(31061);  

如果还是kill不掉,再执行类似以下语句:

SELECT pg_terminate_backend(31390);