一開始,開發童鞋說他在測試環境沒有建立數據庫的權限。心想,不對呀,開發環境沒有怎麼作權限管控,明明給予受權了。
上來一看:sql
postgres=# CREATE DATABASE "abce" WITH OWNER = "a_admin" postgres-# ; ERROR: source database "template1" is being accessed by other users DETAIL: There is 1 other session using the database.
原來不是權限的問題!數據庫
查看一下,誰在使用template1:session
postgres=# select * from pg_stat_activity where DATNAME = 'template1'; datid | datname | pid | usesysid | usename | application_name | client_addr | client_hostname | client_port | backend_start | xact_start | query_ start | state_change | wait_event_type | wait_event | state | backend_xid | backend_xmin | query | backend_type -------+-----------+-------+----------+-----------+------------------+--------------+-----------------+-------------+------------------------------+------------+---------------- ---------------+-------------------------------+-----------------+------------+-------+-------------+--------------+------------------------------------------------------------- ------------------------------------------------------------------------------------------------------------------------------------------+---------------- 1 | template1 | 23498 | 16384 | a_admin | NAVICAT | xx.xx.xx.xxx | | 61664 | 2019-10-08 16:15:06.46307+08 | | 2019-10-08 16:1 5:16.542588+08 | 2019-10-08 16:15:16.545124+08 | Client | ClientRead | idle | | | SELECT rolname, rolsuper, rolinherit, rolcreaterole, rolcrea tedb, rolcanlogin, rolconnlimit, rolvaliduntil, rolconfig, oid , pg_catalog.shobj_description(oid, 'pg_authid') AS comment FROM pg_roles | client backend (1 row)
將查出的pid kill掉app
postgres=# SELECT pg_terminate_backend( 23498); pg_terminate_backend ---------------------- t (1 row)
也可使用一條語句,直接將使用template1的會話kill掉:post
select pg_terminate_backend(pid) from pg_stat_activity where DATNAME = 'template1';
而後再執行數據庫建立語句便可!測試