- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
假设两个同时发生的事务在 Postgresql 数据库上执行以下查询:
事务 A:
SELECT * FROM mytable WHERE id IN (1, 2, 3, 4) FOR UPDATE
事务 B:
SELECT * FROM mytable WHERE id IN (6, 3, 2, 1) FOR UPDATE
Postgresql获取行锁的顺序不一致会不会导致死锁?例如。如果 Postgresql 按照此示例中给出的 ID 的顺序获取行锁,则可能会出现死锁。
或者 Postgresql 是否在内部足够智能以始终以一种方式获取行锁,使得同一个表上的同时、离散的 SELECT FOR UPDATE
语句不会彼此死锁(例如,始终按以下顺序获取行锁)主键)?
如果 Postgresql 不自动防止这种死锁的发生,有没有办法修改查询以防止这种情况(例如,如果实际上 Postgresql 按照 id 的顺序获取行锁给出,然后一致地对 ID 进行排序应该可以防止死锁)?
感谢您的帮助!
最佳答案
抱歉,我有另一个答案,但它错了。
文档指出在 FOR UPDATE 子句之前应用 ORDER BY 子句。因此,无论选择行的顺序如何,都会获取锁(我已经通过测试确认了这一点)。如果您需要以不同的顺序选择它们,您可以使用:
SELECT * FROM (SELECT * FROM table ORDER BY id FOR UPDATE) ORDER BY another_column;
您可能想在 PostgreSQL mailing list 上尝试您的问题.
关于postgresql - 同一张表上的两条 "SELECT FOR UPDATE"语句会导致死锁吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12825663/
我有类似下面的代码: ... id: myComponent signal updateState() property variant modelList: [] Repeater { mo
我正在处理一些我无法展示的私有(private)代码,但我已经制作了一些示例代码来描述我的问题: 主.c: #include #include #include #include typede
这个问题在这里已经有了答案: 关闭10 年前。 Possible Duplicate: what are the differences in die() and exit() in PHP? 我想
在编写 Perl 模块时,在模块内部使用 croak/die 是一个好习惯吗? 毕竟,如果调用者不使用 eval block ,模块可能会使调用它的程序崩溃。 在这些情况下,最佳做法是什么? 最佳答案
我有一些搜索线程正在存储结果。我知道当线程启动时,JVM native 代码会代理在操作系统上创建新 native 线程的请求。这需要 JVM 之外的一些内存。当线程终止并且我保留对它的引用并将其用作
我刚刚花了很多时间调试一个我追溯到 wantarray() 的问题。 .我已将其提炼为这个测试用例。 (忽略 $! 在这种情况下不会有任何有用信息的事实)。我想知道为什么wantarray在第二个示例
我看到一些代码是这样做的: if(something){ echo 'exit from program'; die; } ...more code 和其他只使用 die 的人: if
我正在尝试将此表格用于: 如果任何 $_POST 变量等于任何其他 $_POST 变量抛出错误。 如果只有几个,那不是问题,但我有大约 20 个左右所以如果我想这样做,我将不得不像这样 但这
每次我运行: hadoop dfsadmin -report 我得到以下输出: Configured Capacity: 0 (0 KB) Present Capacity: 0 (0 KB) DFS
我是一名优秀的程序员,十分优秀!