相关疑难解决方法(0)

Oracle选择更新行为

我们试图解决的问题看起来像这样.

  • 我们有一个表满行的表,代表卡片.预订交易的目的是将卡分配给客户
  • 一张卡不能属于许多客户
  • 一段时间后(如果没有购买),必须将卡退回到可用的resurces池中
  • 许多客户可以同时预订
  • 我们使用Oracle数据库来存储数据,因此解决方案必须至少在Oracle 11上运行

我们的解决方案是为卡分配状态,并存储它的预订日期.在预订卡时,我们使用"select for update"语句来完成.该查询查找可用的卡和很久以前保留的卡.

但是,我们的查询无法正常工作.

我准备了一个简化的情况来解释这个问题.我们有一个card_numbers表,充满了数据 - 所有行都有非空的id号.现在,让我们试着锁定其中一些.

-- first, in session 1
set autocommit off;

select id from card_numbers  
where id is not null  
and rownum <= 1  
for update skip locked;
Run Code Online (Sandbox Code Playgroud)

我们不在此处提交事务,必须锁定行.

-- later, in session 2
set autocommit off;

select id from card_numbers  
where id is not null  
and rownum <= 1  
for update skip locked;
Run Code Online (Sandbox Code Playgroud)

预期的行为是,在两个会话中,我们得到一个满足查询条件的不同行.

但是它不起作用.取决于我们是否使用查询的"跳过锁定"部分 - 行为更改:

  • 没有"跳过锁定" - 第二个会话被阻止 - 在第一个会话中等待事务提交或回滚
  • 使用"skip locked" - 第二个查询立即返回空结果集

因此,经过这么长时间的介绍就会出现问题.

Oracle中可能存在所需的锁定行为吗?如果是,那么我们做错了什么?什么是正确的解决方案?

sql oracle locking blocking

18
推荐指数
2
解决办法
4万
查看次数

标签 统计

blocking ×1

locking ×1

oracle ×1

sql ×1