正文
postgresql锁的简单介绍
小程序:扫一扫查出行
【扫一扫了解最新限行尾号】
复制小程序
【扫一扫了解最新限行尾号】
复制小程序
为什么使用postgresql skip locked加锁失败
是因为同时更新事物失误。
通常在数据库中最小粒度的锁是行锁,当一个事务正在更新某条记录时,另一个事务如果要更新同一条记录(或者申请这一条记录的锁),则必须等待锁释放。
通常持锁的时间需要保持到事务结束,也就是说,如果一个长事务持有了某条记录的锁,其他会话要持有这条记录的锁,可能要等很久。
postgresql怎么解锁表
--查询是否锁表了
1、select oid from pg_class where relname='可能被锁掉的表的表名'
,会显示一个oid
2、select pid from pg_locks where relation='刚刚查出来的oid'
--如果查询到了结果(pid),表示该表被锁 则需要释放锁定
select pg_cancel_backend(上面查到的pid)
PostgreSQL 锁表解决
1、查询正在运行的进程
2、查看等待中的进程
3、释放锁定