問題描述數(shù)據(jù)庫訂單表中每個用戶的記錄有15種狀態(tài)(12種狀態(tài)碼代表在途狀態(tài),3種狀態(tài)碼代表終結(jié)狀態(tài))。數(shù)據(jù)之間的狀態(tài)可以進行流轉(zhuǎn)。要求同一個用戶的在途狀態(tài)只能有一條記錄,終結(jié)狀態(tài)可以有多條記錄。如何保證數(shù)據(jù)完整性問題出現(xiàn)的環(huán)境背景及自己嘗試過哪些方法代碼流程,在插入數(shù)據(jù)庫之前進行數(shù)據(jù)查詢,如果查詢出當(dāng)前用戶沒有在途狀態(tài)的數(shù)據(jù),則進行插入;如果查詢出當(dāng)前用戶有在途狀態(tài)的數(shù)據(jù),則不插入。但是在同一個用戶并發(fā)高的情況下,會出現(xiàn)數(shù)據(jù)不嚴謹?shù)那闆r,這個大家都知道。如果是單節(jié)點的情況下,可以使用同步(synchronized)的方法解決數(shù)據(jù)完整性的問題,但是當(dāng)同步的時候也阻塞了其他所有用戶的操作,造成性能低下。
添加回答
舉報
0/150
提交
取消