有一點必須注重的就是多線程程序所帶來的數據完整性問題。對于我們常使用的從數據庫讀取數據到對象中->修改對象屬性->更新到數據庫這個流程,非常輕易出現數據完整性破壞問題。比如一個進程中甲對象讀取數據后,另一個進程中乙對象又修改了同一數據,這時甲對象再次更新數據庫會帶來污寫。解決的辦法是對象增加一個方法給數據庫的這條記錄加鎖。例如Account.getByAccountId函數改為Account.getByAccountIdForUpdate,這個函數中相應的sql語句(Oracle數據庫)改為"select AccountId,name from account where accountId=? for update",這樣數據取出后就自動加鎖,這個鎖將會在事務提交或回滾時釋放。for update在SQLServer相應的語法為holdlock。