【DB吐槽大会】第70期 - PG 不支持update | delete skip locked, nowait语法

简介: 大家好,这里是DB吐槽大会,第70期 - PG 不支持update | delete skip locked, nowait语法

背景


1、产品的问题点

  • PG 不支持update | delete skip locked, nowait语法

2、问题点背后涉及的技术原理

  • NOWAIT | SKIP LOCKED 用于 select for update语句, 锁住某些行, 又不想长时间等待. 提高请求吞吐, 减少等待.
  • nowait 表示如果要锁的行发生了锁冲突, 则直接返回, 不等.
  • skip locked表示跳过有锁冲突的行, 不等待. 例如有10行是符合条件的, 但是有3行发生了行锁冲突, 那么就跳过着3行, 锁其他7行.

3、这个问题将影响哪些行业以及业务场景

  • 通用

4、会导致什么问题?

  • 一般select for update后, 紧接着的大多数都是update或者delete操作, 如果是这样不妨直接支持update | delete skip locked, nowait语法.
  • select for update后, 再执行update或者delete操作, 增加了交互次数, 对于网络较差或者高并发的小事务场景, 性能影响比较大.

5、业务上应该如何避免这个坑

  • 可以使用CTE或CTID子句语法模拟一次交互

6、业务上避免这个坑牺牲了什么, 会引入什么新的问题

  • 需要了解cte语法, ctid子句语法

7、数据库未来产品迭代如何修复这个坑

  • 希望内核可直接支持 update | delete skip locked, nowait 语法, 减少交互次数.
相关文章
|
1月前
|
SQL 关系型数据库 数据库
postgresql报:ERROR: column “i“ of relation “test“ does not exist LINE 1: UPDATE怎么解决?
解决“ERROR: column "i" of relation "test" does not exist”错误的关键在于核实列名的准确性,修正更新语句,确保列名的引用正确无误,并考虑到任何可能影响列名引用的表别名、大小写、特殊字符或动态SQL生成等因素。通过上述步骤,你应该能有效定位并解决问题,保证SQL语句的正确执行。
325 0
|
Oracle 关系型数据库 MySQL
MySQL语句执行报错You can‘t specify target table for update in FROM clause
MySQL语句执行报错You can‘t specify target table for update in FROM clause
87 0
|
SQL 关系型数据库 MySQL
mysql操作中 出现You can‘t specify target table for update in FROM clause错误的解决方法
这个错误实际上也不能称之为咱们sql语句写的不行,实际上是我们在一些细节上没有遵循mysql的语法规范。 问题所在:我们一个sql语句中先select这个表,然后再update这个表的内容。 错误示范: UPDATE StuCose SET Grade=60 WHERE Sno IN( SELECT Sno FROM stucose WHERE Grade<=ALL( SELECT MIN(Grade) FROM stucos
439 0
mysql操作中 出现You can‘t specify target table for update in FROM clause错误的解决方法
|
SQL 关系型数据库 MySQL
mysql Error Code: 1175. You are using safe update mode and you tried to update a table without ....
mysql Error Code: 1175. You are using safe update mode and you tried to update a table without ....
223 0
mysql Error Code: 1175. You are using safe update mode and you tried to update a table without ....
|
关系型数据库 MySQL 数据库
mysql中的update(更新)与alter(更改)以及 change和modify的区别
mysql中的update(更新)与alter(更改)以及 change和modify的区别
1465 0
|
关系型数据库 MySQL
mysql delete where in,mysql delete where not in,You can't specify target table 'member_extend' for u
mysql delete where in,mysql delete where not in,You can't specify target table 'member_extend' for u
213 0
|
消息中间件 SQL 关系型数据库
【DB吐槽大会】第69期 - PG 不支持update | delete limit语法
大家好,这里是DB吐槽大会,第69期 - PG 不支持update | delete limit语法
|
SQL Oracle 关系型数据库
【DB吐槽大会】第62期 - PG 不支持index skip scan
大家好,这里是DB吐槽大会,第62期 - PG 不支持index skip scan
|
关系型数据库 数据库
【DB吐槽大会】第46期 - PG copy不能跳过错误行
大家好,这里是DB吐槽大会,第46期 - PG copy不能跳过错误行
|
SQL 存储 数据库
【DB吐槽大会】第10期 - 不支持 flashback query
大家好,这里是DB吐槽大会,第10期 - 不支持 flashback query

相关实验场景

更多
下一篇
无影云桌面