PB开发境界 多个DW进行update
多個DW進行update
//菜鳥代碼
dw_1.Update()
dw_2.Update()
初級代碼
IF dw_1.Update() = 1 And dw_2.Update() = 1 THEN
??????? COMMIT;
ELSE
??????? ROLLBACK;
END IF
中級代碼
IF dw_1.Update() = 1 THEN
??????? IF dw_2.Update() = 1 THEN
??????????????? COMMIT;
??????? ELSE
??????????????? MessageBox("提示","喝多了!")
??????????????? ROLLBACK;
??????? END IF
ELSE
??????? MessageBox("提示","喝多了!")
??????? ROLLBACK;
END IF
高級代碼
IF dw_1.Update() = 1 THEN
??????? IF dw_2.Update() = 1 THEN
??????????????? COMMIT;
??????? ELSE
??????????????? ROLLBACK;
??????????????? MessageBox("提示","少喝點!")
??????? END IF
ELSE
??????? ROLLBACK;
??????? MessageBox("提示","少喝點!")
END IF
專家級代碼
IF dw_1.Update(True,False) = 1 THEN
??????? IF dw_2.Update(True,False) = 1 THEN
??????????????? dw_1.ResetUpdate()
??????????????? dw_2.ResetUpdate()
??????????????? COMMIT;
??????? ELSE
??????????????? ROLLBACK;
??????????????? MessageBox("提示","沒喝高啊!")
??????? END IF
ELSE
??????? ROLLBACK;
??????? MessageBox("提示","沒喝高啊!")
END IF
多個DW進行update,有時會不能全部成功update 用事務處理時,多個DW進行update后,再COMMIT.偶然會發現前面幾個DW update成功,但后面的表失敗時,好像執行了COMMIT,不會rollback.
正確的寫法如下:
if dw_1.update(true, false)= 1 and dw_2.update(true, false)=1 ...then
? commit;
? dw_1.resetUpdate();
? dw_2.resetUpdate();
else
? rollback;
end if
轉載于:https://blog.51cto.com/12567912/1945986
總結
以上是生活随笔為你收集整理的PB开发境界 多个DW进行update的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 设计一个移动应用的本地缓存机制
- 下一篇: 第一行代码阅读笔记---基本知识