Re: Rollback について
null
投稿数: 191
ようやく、希望する動作が実現出来ましたので自己レスです。
覚書き兼、同じことをやりたい人向けのメモとして書いておきます。
まずは回答ありがとうございました。
ワークテーブルを使用しているのは直接テーブルを更新出来ない
仕様なのでそうなっています。無駄と言う訳ではありません。
後は遅延トランザクションをフル活用すればシンプルになる部分も
あるだろうと思いつつ、すでにある雛形を流用しての開発なので
こうせざるおえないというのもあります。
「たまに上手く戻らないことがある」件については
テーブルコントロール上で Rollback() を発行すると
元に戻った後、フォーカスがある項目だけクリアされる現象があります。
1.9g の RIA で確認しています。これは恐らく不具合でしょうが、
報告しても中々修正されないし、回避策があるので放置することにします。
不味いと思う人は MSJ 辺りに投げてください。
回避策としてはテーブルコントロールから CtrlGoto() で親タスクの
ダミー項目へ移動させた後、Rollback() を発行しています。
前回、エラー発生時は A=アボートとしていましたが、R=復帰に変更しました。
これで、クリアボタン押下時の動作は希望する動作になりました。
ただ前回も書いた通り、終了ボタンを押下時の動作が希望した動作にならないので、
終了ボタン押下時は Rollback() は使用せず、一つタスクを作成して、
それを CALL しています。
そのタスクで何をやっているかと言うと、読取専用テーブルに無理やり更新させ
(ようは何でも良いので例外を発生させる) エラーのイベントハンドラで
発生したイベントを破棄した後、そこで、A=アボートさせることで、
親タスクまるごとアボートするので、Rollback() に近い状態にすることが出来ました。
(このタスクが一つあれば Rollback() は要らない子になりそうな気が…)
Rollback 一発で OK な上、セーブポイントも利用できる他言語に
慣れた人間に話したところ、メンドクサイと苦笑されましたけど、
uniPaaS だから仕方ないよねということにしています。
覚書き兼、同じことをやりたい人向けのメモとして書いておきます。
まずは回答ありがとうございました。
ワークテーブルを使用しているのは直接テーブルを更新出来ない
仕様なのでそうなっています。無駄と言う訳ではありません。
後は遅延トランザクションをフル活用すればシンプルになる部分も
あるだろうと思いつつ、すでにある雛形を流用しての開発なので
こうせざるおえないというのもあります。
「たまに上手く戻らないことがある」件については
テーブルコントロール上で Rollback() を発行すると
元に戻った後、フォーカスがある項目だけクリアされる現象があります。
1.9g の RIA で確認しています。これは恐らく不具合でしょうが、
報告しても中々修正されないし、回避策があるので放置することにします。
不味いと思う人は MSJ 辺りに投げてください。
回避策としてはテーブルコントロールから CtrlGoto() で親タスクの
ダミー項目へ移動させた後、Rollback() を発行しています。
前回、エラー発生時は A=アボートとしていましたが、R=復帰に変更しました。
これで、クリアボタン押下時の動作は希望する動作になりました。
ただ前回も書いた通り、終了ボタンを押下時の動作が希望した動作にならないので、
終了ボタン押下時は Rollback() は使用せず、一つタスクを作成して、
それを CALL しています。
そのタスクで何をやっているかと言うと、読取専用テーブルに無理やり更新させ
(ようは何でも良いので例外を発生させる) エラーのイベントハンドラで
発生したイベントを破棄した後、そこで、A=アボートさせることで、
親タスクまるごとアボートするので、Rollback() に近い状態にすることが出来ました。
(このタスクが一つあれば Rollback() は要らない子になりそうな気が…)
Rollback 一発で OK な上、セーブポイントも利用できる他言語に
慣れた人間に話したところ、メンドクサイと苦笑されましたけど、
uniPaaS だから仕方ないよねということにしています。
投票数:0
平均点:0.00
投稿ツリー
-
Rollback について
(null, 2011-10-28 12:12)
- Re: Rollback について (Tanda, 2011-11-10 18:07)
-
Re: Rollback について
(null, 2011-11-10 23:34)
- Re: Re: Rollback について (Tanda, 2011-11-11 0:14)
- Re: Rollback について (Tanda, 2011-11-11 0:06)