postgresql 查看锁的sql

来源:互联网 发布:超图软件最新消息 编辑:程序博客网 时间:2024/06/08 08:00
  1. SELECT locker.pid,  
  2.         pc.relname,  
  3.         locker.mode,  
  4.         locker_act.application_name,  
  5.         least(query_start,xact_start) start_time,  
  6.         locker_act.state,  
  7.         CASE  
  8.     WHEN granted='f' THEN  
  9.     'wait_lock'  
  10.     WHEN granted='t' THEN  
  11.     'get_lock'  
  12.     END lock_satus,current_timestamp - least(query_start,xact_start) AS runtime,  
  13.     locker_act.query  
  14. FROM pg_locks locker,pg_stat_activity locker_act, pg_class pc  
  15. WHERE locker.pid=locker_act.pid  
  16.         AND NOT locker.pid=pg_backend_pid()  
  17.         AND application_name<>'pg_statsinfod'  
  18.         AND locker.relation = pc.oid  
  19.         AND pc.reltype<>0 --and pc.relname='t' 
  20. ORDER BY  runtime desc;

  1. --查看PostgreSQL正在执行的SQL   
  2. SELECT   
  3.     procpid,   
  4.     start,   
  5.     now() - start AS lap,   
  6.     current_query   
  7. FROM   
  8.     (SELECT   
  9.         backendid,   
  10.         pg_stat_get_backend_pid(S.backendid) AS procpid,   
  11.         pg_stat_get_backend_activity_start(S.backendid) AS start,   
  12.        pg_stat_get_backend_activity(S.backendid) AS current_query   
  13.     FROM   
  14.         (SELECT pg_stat_get_backend_idset() AS backendid) AS S   
  15.     ) AS S ,pg_stat_activity pa  
  16. WHERE   
  17.    current_query <> '<IDLE>' and  procpid<> pg_backend_pid() and pa.pid=s.procpid and pa.state<>'idle'  
  18. ORDER BY   
  19.    lap DESC;  

  1.    
  2. procpid:进程id  
  3. start:进程开始时间  
  4. lap:经过时间  
  5. current_query:执行中的sql  
  6. 怎样停止正在执行的sql  
  7. SELECT pg_cancel_backend(进程id);  
  8. 或者用系统函数  
  9. kill -9 进程id;  



  1. --查找是否有waiting  
  2. ps -ef|grep postgres | grep wait  

  1. --查看当前库表和索引的的大小并排序显示前20条  
  2. SELECT  
  3. nspname,  
  4. relname,  
  5. relkind as "type",  
  6. pg_size_pretty(pg_table_size(C.oid)) AS size,  
  7. pg_size_pretty(pg_indexes_size(C.oid)) AS idxsize,  
  8. pg_size_pretty(pg_total_relation_size(C.oid)) as "total"  
  9. FROM pg_class C  
  10. LEFT JOIN pg_namespace N ON (N.oid = C.relnamespace)  
  11. WHERE nspname NOT IN ('pg_catalog', 'information_schema') AND  
  12. nspname !~ '^pg_toast' AND  
  13. relkind IN ('r','i')  
  14. ORDER BY pg_total_relation_size(C.oid) DESC  
  15. LIMIT 20;  

原创粉丝点击