- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在我的 Rails 4 应用程序中,我对 Postgres 9.4 数据库进行了以下查询:
@chosen_opportunity = Opportunity.find_by_sql(
" UPDATE \"opportunities\" s
SET opportunity_available = false
FROM (
SELECT \"opportunities\".*
FROM \"opportunities\"
WHERE ( deal_id = #{@deal.id}
AND opportunity_available = true
AND pg_try_advisory_xact_lock(id) )
LIMIT 1
FOR UPDATE
) sub
WHERE s.id = sub.id
RETURNING sub.prize_id, sub.id"
)
非常受 this related answer on dba.SE 启发.
我只想让我的查询找到并更新第一个(随机地,使用 LIMIT
)行,其中 available = true
并将其更新为 available = false
,并且我需要在执行此操作时锁定该行,但不需要等待释放前一个锁定而发出新请求,因为有许多并发调用将使用此查询。
但我还看到了 FOR UPDATE
的 NOWAIT
选项。我不确定我是否理解使用 pg_try_advisory_xact_lock()
和 NOWAIT
选项之间的区别,在我看来它们实现了相同的目标:
To prevent the operation from waiting for other transactions to commit, use the
NOWAIT
option.
pg_try_advisory_xact_lock
's goal
不是等待上一个事务释放锁,仍然可以做下一个事务,只操作下一个select更新'还没有加锁'的行。
哪个更适合我的需求?
最佳答案
只有在您坚持锁定特定行时才是一个好主意,而这不是 你需要什么。您只需要任何 符合条件的可用(未锁定)行。重要的区别在于(quoting the manual for Postgres 9.4):FOR UPDATE NOWAIT
With
NOWAIT
, the statement reports an error, rather than waiting, if a selected row cannot be locked immediately.
相同的查询很可能会尝试锁定相同的任意选择。 FOR UPDATE NOWAIT
只会抛出异常(这将回滚整个事务,除非您捕获错误)并且您必须重试。
我在 dba.SE 上引用的答案中的解决方案结合了普通 FOR UPDATE
和 pg_try_advisory_lock()
:
pg_try_advisory_lock
is similar topg_advisory_lock
, except the function will not wait for the lock to become available. It will either obtain the lock immediately and return true, or return false if the lock cannot be acquired immediately.
所以您的最佳选择是……第三种选择:Postgres 9.5 中新的FOR UPDATE SKIP LOCKED
,它实现了相同的无需额外函数调用的行为。
The manual for Postgres 9.5比较这两个选项,进一步解释差异:
To prevent the operation from waiting for other transactions to commit, use either the
NOWAIT
orSKIP LOCKED
option. WithNOWAIT
, the statement reports an error, rather than waiting, if a selected row cannot be locked immediately. WithSKIP LOCKED
, any selected rows that cannot be immediately locked are skipped.
在 Postgres 9.4 或更早版本上,您的下一个最佳选择是结合使用 pg_try_advisory_xact_lock(id)
和 FOR UPDATE
,如引用文献中所示回答:
(还有一个带有 FOR UPDATE SKIP LOCKED
的实现。)
严格来说,您的选择是任意的,而不是真正的随机选择。这可能是一个重要的区别。
您查询的审核版本在 my answer to your other question 中.
关于sql - 建议锁定或 NOWAIT 以避免等待锁定的行?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33129132/
我对 Java 并发性比较陌生(还没有阅读 JCIP,但它在我的列表中!)并且我有一个关于锁定行为的问题。具体来说,Java 是锁定对象的引用,还是锁定对象本身? 代码示例(不是 sscce,因为我不
我的团队使用 TortoiseSVN 编写版本控制代码。有时,有人使用“获取锁定”选项。是否有可能看到解决方案中的锁? 最佳答案 http://tortoisesvn.net/docs/nightly
我在使用 SVN 时遇到了一个小问题。 当我跑 svn stat我明白了: ~ some/dir 当我跑 svn commit -m "test"我明白了:svn: working copy
我启用了 jenkins 安全性,认为它会提示我创建一个帐户。我尝试在 c:/program files/jenkins 中删除和编辑我的 config.xml 文件,但我不确定如何在没有访问权限的情
实现与 S3 结合使用的简单锁定机制的推荐方法是什么? 我想做的例子: 通过对象 ID 获取锁 从 S3 读取对象 修改数据 将对象写入 S3 释放锁 理想情况下寻找基于云的锁定机制。我可以在本地使用
找到这个here : 一般来说,在以下任何情况下,请考虑在列上创建索引: 索引列上存在引用完整性约束,或者列。索引是避免全表锁的一种方法,否则,如果您更新父表主键,则需要,合并到父表中,或从父表中删除
在我的程序中,我将把每个“ block ”数据存储在一个单独的文件中。多个线程都会读取和写入各种文件,我想避免因未正确同步而可能出现的问题。本质上,我想要一个设置,其中每个文件的行为就好像它有自己的
我想使用此script作为资源,通过使用Windows API(重置管理器)与Go for Windows中的内容相同 到目前为止,我的代码是 Rstrtmgr := syscall.NewLazyD
这里的问题是:“这些选择中的哪一个对于线程安全选择的剧院具有最佳性能?” public static List lockList = initializeLocks(); public boolean
我有一个侧面菜单,单击图标时打开,单击页面或单击菜单上的项目时关闭。我正在尝试实现锁定,因此当单击锁定图标时,即使您单击菜单项或页面,菜单也不会关闭。 我能够将图标从锁定图标更改为解锁图标,但我在停止
使用 TRueType 字体编写 SDL 程序。我调用 TTF_Init() 来初始化 TTF 并使用 TTF_OpenFont( name, size ) 打开我的字体。 我有一个例程,可以使用以下
我正在尝试调试基于运行 FreeRTOS 的 STM32F3 uC 的应用程序。我已在应用程序的线程上下文中的随机位置手动将 PSP 设置为无效值(例如 0),希望触发 memManageFault/
我有以下 C# 代码: 1. List bandEdgeList; 2. 3. bandEdgeList = CicApplication.BandEdgeCache.Where(r
我正在用骰子制作游戏。这个想法是持有/锁定骰子。我把骰子做成按钮,这样现在就可以点击它们了。示例:我抛出一个“6”和一个“1”。我点击“6”,所以现在只会抛出“1”。 我对这个有点迷失了,我需要创建
我正在使用以下代码下载约 200mb 的播客并将其写入文档目录: var podcastRequest = NSURLRequest(URL: audioUrl) NSURLConnection.se
下面的类 DoStuff 启动一个线程并同步以保护监听器对象在 null 时不被访问。 现在,当从外部访问 DoStuff 类函数 setOnProgressListener() 时,我遇到了问题,因
我正在编写一个使用巨大背景 Canvas 的网站。我试图锁定浏览器调整大小处理程序以避免滚动问题(背景越界等) 这是我第一次做一个完整的后台网站。任何有关优化的建议(png 大小 580.72 KB
我是 C# 和线程的新手,我有这个问题要解决: 我有一个处理一些数据的线程,它会不时(必要时)触发我在启动线程之前设置的事件方法 (DataProcessor)。该线程位于专有 dll 中。所以我不能
我正在使用相机,我使用的是文档中给出的完全相同的示例: http://developer.android.com/resources/samples/ApiDemos/src/com/example/
我有几个座位可供用户预订。同一时间,只有一个用户可以参与预订过程,这样同一个座位就不会被多个用户预订。在我的 Java 代码中,我使用了“synchronized”关键字来完成它。这行得通。 但是,现
我是一名优秀的程序员,十分优秀!