PostgreSQL LOCK(锁)

锁主要是为了保持数据库数据的一致性,可以阻止用户修改一行或整个表,一般用在并发较高的数据库中。

在多个用户访问数据库的时候若对并发操作不加控制就可能会读取和存储不正确的数据,破坏数据库的一致性。

数据库中有两种基本的锁:排它锁(Exclusive Locks)和共享锁(Share Locks)。

如果数据对象加上排它锁,则其他的事务不能对它读取和修改。

如果加上共享锁,则该数据库对象可以被其他事务读取,但不能修改。

LOCK 命令语法

LOCK 命令基础语法如下:

LOCK [ TABLE ]

name

IN

lock_mode

name:要锁定的现有表的名称(可选模式限定)。如果只在表名之前指定,则只锁定该表。如果未指定,则锁定该表及其所有子表(如果有)。

lock_mode:锁定模式指定该锁与哪个锁冲突。如果没有指定锁定模式,则使用限制最大的访问独占模式。可能的值是:ACCESS SHARE,ROW SHARE, ROW EXCLUSIVE, SHARE UPDATE EXCLUSIVE, SHARE,SHARE ROW EXCLUSIVE,EXCLUSIVE,ACCESS EXCLUSIVE。

一旦获得了锁,锁将在当前事务的其余时间保持。没有解锁表命令;锁总是在事务结束时释放。

死锁

当两个事务彼此等待对方完成其操作时,可能会发生死锁。尽管 PostgreSQL 可以检测它们并以回滚结束它们,但死锁仍然很不方便。为了防止应用程序遇到这个问题,请确保将应用程序设计为以相同的顺序锁定对象。

咨询锁

PostgreSQL 提供了创建具有应用程序定义含义的锁的方法。这些被称为咨询锁。由于系统不强制使用它们,所以正确使用它们取决于应用程序。咨询锁对于不适合 MVCC 模型的锁定策略非常有用。

例如,咨询锁的一个常见用途是模拟所谓"平面文件"数据管理系统中典型的悲观锁定策略。虽然存储在表中的标志可以用于相同的目的,但是通知锁更快,避免了表膨胀,并且在会话结束时由服务器自动清理。

实例

创建 COMPANY 表(下载 COMPANY SQL 文件 ),数据内容如下:

runoobdb# select * from COMPANY;

id | name | age | address | salary

----+-------+-----+-----------+--------

1 | Paul | 32 | California| 20000

2 | Allen | 25 | Texas | 15000

3 | Teddy | 23 | Norway | 20000

4 | Mark | 25 | Rich-Mond | 65000

5 | David | 27 | Texas | 85000

6 | Kim | 22 | South-Hall| 45000

7 | James | 24 | Houston | 10000

(7 rows)

下面的示例将 runoobdb 数据库中的 COMPANY 表锁定为 ACCESS EXCLUSIVE 模式。

LOCK 语句只在事务模式下工作。

runoobdb=#BEGIN;

LOCK TABLE company1 IN ACCESS EXCLUSIVE MODE;

上面操作将得到下面结果:

LOCK TABLE

上面的消息指示表被锁定,直到事务结束,并且要完成事务,您必须回滚或提交事务。

pg库sharelock_PostgreSQL LOCK(锁)相关推荐

  1. pg库sharelock_PostgreSQL 行锁解读

    像其它数据库一样,PostgreSQL数据库不仅有表级别的锁,同时也有行级别的锁.行锁对于提高系统的并行度至关重要.那么PostgreSQL是如何实现行锁的呢? PostgreSQL获取行锁的大致分为 ...

  2. Java5线程并发库之LOCK(锁)CONDITION(条件)实现线程同步通信

    为什么80%的码农都做不了架构师?>>>    Lock(锁)&Condition(条件)实现线程同步通信 接下来介绍,java5线程并发库里面的锁.跟锁有关的类和接口主要是 ...

  3. PostgreSql Lock锁

    内容摘自:http://blog.sina.com.cn/s/blog_79d599dc0100qpos.html 上一篇里面提到了PG里面的事务控制级别,是因为上午的一个应用程序跑的过程中,死在DE ...

  4. JUC多线程:synchronized锁机制原理 与 Lock锁机制

    前言: 线程安全是并发编程中的重要关注点,造成线程安全问题的主要原因有两点,一是存在共享数据(也称临界资源),二是存在多条线程共同操作共享数据.因此为了解决这个问题,我们可能需要这样一个方案,当存在多 ...

  5. mysql读写分离主从原理、事务隔离级别及使用、锁表和锁行场景、乐观锁和悲观锁、lock锁和sychronized区别及使用自己学习之后总结和参考一些博客感觉系统了解了

    synchronized与Lock的区别 两者区别: 1.首先synchronized是java内置关键字,在jvm层面,Lock是个java类: 2.synchronized无法判断是否获取锁的状态 ...

  6. 【解决线程安全问题:通过Lock锁对象】

    [解决线程安全问题:通过Lock锁对象] 参考文章: (1)[解决线程安全问题:通过Lock锁对象] (2)https://www.cnblogs.com/zuixinxian/p/9570409.h ...

  7. java:lock锁

    synchronized锁效率比较低,不方便扩展,不能自定义.于是从jdk1.5之后,就引入了lock锁. lock可以手动上锁,手动释放锁,灵活性很高. Lock lock = new Reentr ...

  8. Lock锁的基本使用

    在jdk1.5后新增的ReentrantLock类同样可达到此效果,且在使用上比synchronized更加灵活 相关API: 使用ReentrantLock实现同步 lock()方法:上锁 unlo ...

  9. 深入Lock锁底层原理实现,手写一个可重入锁

    synchronized与lock lock是一个接口,而synchronized是在JVM层面实现的.synchronized释放锁有两种方式: 获取锁的线程执行完同步代码,释放锁 . 线程执行发生 ...

最新文章

  1. 【无私分享:从入门到精通ASP.NET MVC】从0开始,一起搭框架、做项目(7.2) 模块管理,模块的添加、修改、删除...
  2. clion 远程调试配置失败 Failed to reload 错误
  3. android从放弃到精通 第一天 重拾项目开发
  4. 2020-12-7(字节,半字,字,双字总结)
  5. 分布式ID生成器(来源:架构师之路,2017-06-25 58沈剑 架构师之路)
  6. linux whois rpm,CentOS系统安装whois命令的方法
  7. rm: cannot remove directory `test': Permission denied
  8. 纪念中学15-5(=10)天感想
  9. 如何有效维护PDH光端机的常见故障?
  10. 网页常用Javascript
  11. 推荐一篇文章,.net3.0新特性
  12. android jni java调用c,Android与JNI(一) ---- Java调用C 静态调用
  13. java验证码工具_java 验证码工具
  14. SQLi LABS Less-18
  15. Java Servlet Filter
  16. Miro Video Converter针对FFMPEG转换参数
  17. java代码做一个电子表
  18. 手写实现bpnn神经网络
  19. 老师用计算机教我们画画拼音,小学一年级语文《汉语拼音13angengingong》第三课时教学设计.docx...
  20. 奇瑞汽车召回部分瑞虎3xe纯电动汽车 共计8580辆

热门文章

  1. OpenShift 4 - 通过设置SDN的NetworkPolicy定义Pod访问策略
  2. (三)用于构建AI语言翻译系统的工具
  3. 实例解读Docker Swarm
  4. 创建用于图像大小调整和裁剪器保持纵横比的ASP.NET控件
  5. Android 10 正式版本或将于 9 月 3 日推出
  6. Android Q 不叫 Q,正式命名为 Android 10
  7. 计算机应用与软件修审,国中课室素养导向标准本位评量的设计与应用:以英语科阅读为例...
  8. 手机4g模块坏了怎么办_古交联通突然断网,手机没信号,不能接打电话该怎么办?...
  9. css animate属性spend不生效
  10. oracle显示数据中心类异常,Oracle_10g数据库基础教程-参考答案