查看窗口连接到的服务进程的pid。
select pg_backend_pid();三个窗口的pid分别如下:
查询结果如下:
其中,各列的含义如下:
列名含义locktype被锁定对象的类型relation表。如果对象不是表或表的一部分,则此值为null。virtualxid虚拟事务ID。如果对象虚拟事务,则此值为null。transactionid事务ID。如果对象不是事务,则此值为mull。virtualtransaction持有或等待这把锁的虚拟事务的ID。pid持有或等待这把锁的服务进程pid。mode锁的模式名称。granted锁已被持有,则为ture;如果等待获得此锁,此值为false。查询结果的第一行表示:事务在自己的“virtualxid”上加“ExclusiveLock”锁。
第二行表示:在表person上加锁“AccessExclusiveLock”。
执行锁表命令后,并没有进行实际的修改操作,此时transactionid为null,这表明:事务ID在实际需要的时候才产生。
由于第一个窗口已经对person表加锁,所以第二个窗口的锁表语句会被阻塞住。
mydb=# begin; BEGIN mydb=# lock table person;由上图可知:进程28924,2052都对表person加了锁。但进程28924的granted为t,表示它获得了这个锁。进程2052的granted为f,表示它没有获得这把锁,从而被阻塞了。