請教一下資料庫同步的問題
假設一個訂票系統有一個table:座位
欄位有日期、座位號碼、是否available、訂位人的ID
現在有兩個user: A, B進入了訂票系統
接著發生了以下事件
1. A select此table發現有五個空位
2. B select此table發現有五個空位
3. A 訂了四個位子,並且把這四個位子的狀態update為unavailable
4. A結束transaction
5. 現在B以為有五個空位,於是訂了兩個位子 => 發生重複訂位的問題
請問一下,有什麼辦法解決這個同步的問題?
我想到的方法是在事件1發生時讓A對table作lock,然後B要等到A結束transaction
才能select
不過這方法效率似乎不好,有更好的方法嗎?
--
※ 發信站: 批踢踢實業坊(ptt.cc)
◆ From: 114.42.9.22
推
10/05 20:40, , 1F
10/05 20:40, 1F
→
10/06 21:20, , 2F
10/06 21:20, 2F
→
10/06 21:26, , 3F
10/06 21:26, 3F
討論串 (同標題文章)
以下文章回應了本文:
完整討論串 (本文為第 1 之 2 篇):