我遇到了一個問題,不知道如何用DB實現(xiàn)它。我在應(yīng)用程序方面已經(jīng)走了。我有產(chǎn)品表,其中列被指定為 .當(dāng)有人點擊 API 時,我需要將端口分配給服務(wù)。它需要根據(jù)其產(chǎn)品名稱遞增 by。last_port_usedlast_port_id1一種可能的解決方案是使用redis服務(wù)器并在那里同步此值。因為我們沒有redis。我想通過.psql我讀了更多關(guān)于鎖的信息,我認(rèn)為我需要鎖。這是正確的方法嗎?ACCESS EXCLUSIVEproductidnamestart_port //11000end_port//11999last_port_used// 11023如何同時正確處理?
1 回答

侃侃無極
TA貢獻(xiàn)2051條經(jīng)驗 獲得超10個贊
您可以簡單地執(zhí)行以下操作:
UPDATE products SET last_port_used = last_port_used+1
WHERE id=...
AND last_port_used < end_port
RETURNING *
這將以線程安全的方式執(zhí)行更新,并且僅當(dāng)端口號可用(last_port_used < end_port)并返回分配的端口時。
如果需要鎖定該行,還可以使用“選擇以進(jìn)行更新”。
- 1 回答
- 0 關(guān)注
- 106 瀏覽
添加回答
舉報
0/150
提交
取消