Oracle ADF基于AM的两种回滚写法及切换行事件(附代码) |
发布时间: 2012/8/31 17:31:50 |
在进行行编辑时,难免会遇到切换行的时候。 则需要有切换行事件,PopUp弹出 确定时提交 取消时回滚。 af:table组件有selectionListener属性, 默认情况下 都是 selectionListener="#{bindings.[VO名].collectionModel.makeCurrent}" 现在如果需要获取换行的动作 则要在自己的managebean方法写此方法 如: selectionListener="#{pageFlowScope.[VO名].tableSelectionListener}" 其中pageFlowScope是我的managebean的生命周期,tableSelectionListener是我定义的 获取selectionListener的监听方法 1.public void tableSelectionListener(SelectionEvent selectionEvent,ViewObjectImpl vo) throws Exception { GenericTableSelectionHandler.makeCurrent(selectionEvent);写的位置也很重要 <>如果写在函数的最初,则获取到currentRow为切换后的行,www.linuxidc.com 在此句之前执行的currentRow都为切换行之前的currentRow. 代码中JSFUitls.findComponentInRoot("confirm2")为找到 id为confirm2的组件 UI上是这么写的: <af:popup autoCancel="enabled" id="afterCommit" animate="default"
确定走makeSureButtonAction,取消走makeNoButtonAction 确定就把am提交。取消则回滚。 介绍两种回滚方式: 1。数据库回滚,am.getDBTransaction().rollback();通过得到am的dbtransaction的回滚方法 界面上的值也会回滚成数据库的值 2. 同样是数据库的回滚 am.getDBTransaction().createPreparedStatement("commit", 1).getConnection().rollback(); 与1的区别为界面上的值是不会回滚成数据库的值的,仍然保留更改过的值 本文出自:亿恩科技【www.enkj.com】 |