我的编程空间,编程开发者的网络收藏夹
学习永远不晚

PostgreSQL Locks的基础知识有哪些

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

PostgreSQL Locks的基础知识有哪些

这篇文章主要介绍“PostgreSQL Locks的基础知识有哪些”,在日常操作中,相信很多人在PostgreSQL Locks的基础知识有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”PostgreSQL Locks的基础知识有哪些”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

PostgreSQL把锁分为三类,table-level, row-level and advisory locks.Table和Row级锁可以是显式或隐式锁,advisory locks通常是显式锁.显式锁在显式用户请求时获得,而隐式锁则通过标准SQL命令获得.

Advisory Locks
PG提供了应用自定义的locks,这种locks称为Advisory Locks — 系统并没有强制使用这些锁,由应用自行正确使用.
有两种方法请求获取advisory lock : Session Level和Transaction Level.
session level : 一旦在session level获取了锁,除非session终止或者显式的释放,否则锁会一直持有.不同于标准的锁请求,session level的advisory lock不需要遵守事务语义:在事务期间申请的lock会在rollback后仍会持有,同时就算事务调用失败unlock也是有效的.lock可以多次获取,对于每一次完整的锁请求必须在释放锁前有相应的unlock.
transaction level : 与普通锁类似,在事务结束时自动释放,没有显式的unlock操作.
对于同一个Advisory Lock,如果同时请求session leve和transaction level的锁,那么会以期望的方式阻塞.
下面是Advisory Lock的例子:

session 1

[local]:5432 pg12@testdb=# -- Transaction 1
[local]:5432 pg12@testdb=# BEGIN;
BEGIN
Time: 0.882 ms
[local]:5432 pg12@testdb=#* 
[local]:5432 pg12@testdb=#* SELECT pg_advisory_xact_lock(1);
 pg_advisory_xact_lock 
-----------------------
(1 row)
Time: 2.449 ms
[local]:5432 pg12@testdb=#* -- Some work here
[local]:5432 pg12@testdb=#*

session 2

[local]:5432 pg12@testdb=# -- Transaction 2
[local]:5432 pg12@testdb=# BEGIN;
BEGIN
Time: 0.468 ms
[local]:5432 pg12@testdb=#* 
[local]:5432 pg12@testdb=#* SELECT pg_advisory_xact_lock(1);

session 3

[local]:5432 pg12@testdb=# SELECT * FROM pg_locks where pid <> pg_backend_pid();
  locktype  | database | relation | page | tuple | virtualxid | transactionid | classid | objid | objsubid | virtualtransaction | pid  |     mode      | granted | fastpath 
------------+----------+----------+------+-------+------------+---------------+---------+-------+----------+--------------------+------+---------------+---------+----------
 virtualxid |          |          |      |       | 5/4        |               |         |       |          | 5/4                | 1789 | ExclusiveLock | t       | t
 virtualxid |          |          |      |       | 4/13       |               |         |       |          | 4/13               | 1787 | ExclusiveLock | t       | t
 advisory   |    16384 |          |      |       |            |               |       0 |     1 |        1 | 5/4                | 1789 | ExclusiveLock | t       | f
 advisory   |    16384 |          |      |       |            |               |       0 |     1 |        1 | 4/13               | 1787 | ExclusiveLock | f       | f
(4 rows)
Time: 3.748 ms

通过查询pg_locks,可以看到pid 1789持有advisory lock(granted = t),而pid 1787在等待该锁(granted = f).

到此,关于“PostgreSQL Locks的基础知识有哪些”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

PostgreSQL Locks的基础知识有哪些

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

C++的基础知识有哪些

这篇文章主要介绍“C++的基础知识有哪些”,在日常操作中,相信很多人在C++的基础知识有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”C++的基础知识有哪些”的疑惑有所帮助!接下来,请跟着小编一起来学习吧
2023-06-16

centos的基础知识有哪些

这篇文章主要讲解了“centos的基础知识有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“centos的基础知识有哪些”吧!1. 请回答,32位和64位有什么区别呢?什么时候安装32位的
2023-06-10

shell的基础知识有哪些

这篇“shell的基础知识有哪些”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“shell的基础知识有哪些”文章吧。shell
2023-06-27

Kubernetes的基础知识有哪些

这篇“Kubernetes的基础知识有哪些”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Kubernetes的基础知识有哪些
2023-06-29

Java的基础知识有哪些

这篇文章主要介绍“Java的基础知识有哪些”,在日常操作中,相信很多人在Java的基础知识有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Java的基础知识有哪些”的疑惑有所帮助!接下来,请跟着小编一起来
2023-06-02

java.nio.Buffer的基础知识有哪些

这篇文章主要讲解了“java.nio.Buffer的基础知识有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“java.nio.Buffer的基础知识有哪些”吧!capacity(): 表
2023-06-17

Socket基础知识有哪些

本篇文章给大家分享的是有关Socket基础知识有哪些,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。如何一步步掌握Socket相关的知识。什么是Socket?大家都用电脑上网,当
2023-06-04

VUE基础知识有哪些

这篇文章主要为大家展示了“VUE基础知识有哪些”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“VUE基础知识有哪些”这篇文章吧。VUE是什么Vue (读音 /vjuː/,类似于 view) 是一套
2023-06-25

编程热搜

目录