久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁技術文章
文章詳情頁

在Oracle數據庫中處理數據的高并發響應

瀏覽:12日期:2023-11-27 14:04:33

某些系統可能對系統應付數據高并發的響應要求比較高 (如: 飛行航空訂票系統). 本文采用Oracle的lock table來解決此問題:

Procedure中關鍵code如下:

---------------------------------------

lock table tb_book_ticket in share mode;

...

insert into tb_book_ticket (id, scheduled_flight, ticket_no, book_time) values (ID.nextval, v_scheduled_flight, v_ticket_no, SYSDATE); -- mark1

... -- mark2

select count(*) into v_book_count from tb_book_ticket where scheduled_flight = v_scheduled_flight; -- mark3

if v_book_count <= v_book_max_count then

v_result := 'book successfully';

commit;

else

v_result := 'book unsuccessfully';

rollback;

end if;

return v_result;

-------------------------------------------------------------

以上有2個地方需注意:

1) 采用 lock table table_name in share mode 方式而非 lock table table_name in exclusive mode 提高并發性處理, 盡量減少不必要執行等待.

2) 按常規思路, 可能會將 mark1 與 mark3 順序交換, 但此舉不行

-------------------------------------------------------------

select count(*) into v_book_count from tb_book_ticket where scheduled_flight = v_scheduled_flight; -- mark3

... -- mark2

if v_book_count < v_book_max_count then

insert into tb_book_ticket (id, scheduled_flight, ticket_no, book_time) values (ID.nextval, v_scheduled_flight, v_ticket_no, SYSDATE); -- mark1

-- mark4

commit;

end if;

-------------------------------------------------------------

試想若 userA 執行到 mark4, 而同時 userB 執行到 mark3, 就可能會出現由于 userA 尚未commit 而導致 userB 訂到機票但實際沒有座位的情況。

若確希望使用常規邏輯來實現, 需要用到 Oracle 的表的讀鎖功能 (精細訪問策略), 而此非本文范圍, 且其對于SYS用戶無效。

標簽: Oracle 數據庫
主站蜘蛛池模板: 一区二区三区四区精品 | а天堂中文官网 | 精品视频久久 | 久久久久国产一区二区三区 | 亚洲男人的天堂在线播放 | 精品一区二区三区蜜桃 | 国产精品粉嫩白浆在线观看 | 免费观看a视频 | 麻豆精品久久久 | 久久高清 | 久久精品国产亚洲一区二区三区 | 免费一区二区 | 91视频免费在线 | 在线观看视频一区二区 | 日韩喷潮 | 国产干干干 | 国产电影精品久久 | 欧美日韩中文在线 | 日韩欧美视频 | 国产精品久久久久久久天堂 | 久久久久久免费毛片精品 | 亚洲性人人天天夜夜摸 | 欧美视频精品在线 | 国产成人av在线 | 国产老头老太作爱视频 | 黄网在线观看 | 欧美激情一区 | 伊人网在线视频观看 | 精品一区国产 | 成人免费大片黄在线播放 | 亚洲精品高清视频 | 一区二区av | 亚洲欧美日本在线 | 免费的一级视频 | 国产高清在线精品 | 久草中文在线 | 91社区在线观看高清 | 久草视频在线播放 | 免费看的毛片 | 国产亚洲二区 | 男人天堂99 |