国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

java - mybatis怎么處理事務問題

瀏覽:160日期:2024-01-21 11:38:58

問題描述

我用的mybatis是基于SqlSessionTemplate實現的,如下:

@Repository('daoSupport')public class DaoSupport implements BaseDAO { @Resource(name = 'sqlSessionTemplate') private SqlSessionTemplate sqlSessionTemplate;/** * 保存對象 * @param str * @param obj * @return * @throws Exception */ public Object save(String str, Object obj){return sqlSessionTemplate.insert(str, obj); }/** * 批量更新 * @param str * @param obj * @return * @throws Exception */ public Object batchSave(String str, List objs){return sqlSessionTemplate.insert(str, objs); }/** * 修改對象 * @param str * @param obj * @return * @throws Exception */ public Object update(String str, Object obj){Integer count=sqlSessionTemplate.update(str, obj);

@Service

public class OrderInfoService { @Resource(name = 'daoSupport') private DaoSupport dao;@SuppressWarnings('unchecked') public List<PageData> getPerson() { List<PageData> a =(List<PageData>)dao.findAllList( 'OrderInfoMapper.getOrderInfo'); return a; } public void save(PageData pd){dao.save('OrderInfoMapper.saveOrderInfo', pd); } public void update(PageData pd){dao.update('OrderInfoMapper.updateOrder', pd); }@SuppressWarnings('unchecked') public List<PageData> list(PageData pd){return (List<PageData>)dao.findForList('OrderInfoMapper.getOrderInfo', pd); }

在xml文件里面寫對應sql的Mapper,我想在調用service層的方法操作數據庫時,幾條sql語句同時commit,其中有一條失敗則全部不執行,就和jdbc那樣先設置不自動commit,然后在commit那種,要在哪里配置或調用啥方法實現?

問題解答

回答1:

請百度spring的事務管理

第一種,配置事務管理的規則,具體怎么寫可以再百度,一兩句說不清

<bean class='org.springframework.jdbc.datasource.DataSourceTransactionManager'><property name='dataSource' ref='dataSource'/> </bean> <aop:config><aop:pointcut expression='execution(* com.web..*.services..*Impl.*(..))'/><aop:advisor advice-ref='txAdvice' pointcut-ref='interceptorPointCuts'/> </aop:config> <tx:advice transaction-manager='transactionManager'><tx:attributes> <tx:method name='save*' propagation='REQUIRED' rollback-for='java.lang.Exception'/> <tx:method name='update*' propagation='REQUIRED' rollback-for='java.lang.Exception'/> <tx:method name='insert*' propagation='REQUIRED' rollback-for='java.lang.Exception'/> <tx:method name='delete*' propagation='REQUIRED' rollback-for='java.lang.Exception'/>for='java.lang.Exception'/> --></tx:attributes> </tx:advice>

第二種使用注解@Transactional

<bean class='org.springframework.jdbc.datasource.DataSourceTransactionManager'><property name='dataSource' ref='dataSource'/> </bean> <!--聲明使用注解式事務--> <tx:annotation-driven transaction-manager='transactionManager'/>回答2:

Programmatic Transaction Management MyBatis SqlSession provides youwith specific methods to handle transactions programmatically. Butwhen using MyBatis-Spring your beans will be injected with a Springmanaged SqlSession or a Spring managed mapper. That means that Springwill always handle your transactions.

You cannot call SqlSession.commit(), SqlSession.rollback() orSqlSession.close() over a Spring managed SqlSession. If you try to doso, a UnsupportedOperationException exception will be thrown. Notethese methods are not exposed in injected mapper classes.

Regardless of your JDBC connection’s autocommit setting, any executionof a SqlSession data method or any call to a mapper method outside aSpring transaction will be automatically committed.

If you want to control your transactions programmatically please referto chapter 10.6 of the Spring reference manual. This code shows how tohandle a transaction manually using the PlatformTransactionManagerdescribed in section 10.6.2.

mybatis-spring

回答3:

Spring好像不允許手動提交事務,Spring容器會自動管理事務!java - mybatis怎么處理事務問題

回答4:

//使用事務處理,訂單及貨物訂單必須同時插進2個表里面@Transactional(rollbackFor=Exception.class)public void save(PageData pd,Map<String,Integer> map,String uuid,int Uid){ dao.save('OrderInfoMapper.saveOrderInfo', pd); OrderGood orderGood=new OrderGood(); for(String gid:map.keySet()){Goods good=goodService.findOne(gid);orderGood.setGname(good.getGname());//Integer a=map.get(gid);orderGood.setOgamount(map.get(gid));orderGood.setGid(Integer.parseInt(gid));orderGood.setOgtotalprize(map.get(gid)*good.getGprice());orderGood.setUid(Uid);orderGood.setOid(uuid);dao.save('OrderInfoMapper.saveOrderGood', orderGood);} }使用@Transactional 注解則成功解決問題,此注解是spring 的事務管理,使用前先配置如下:

<bean class='org.springframework.jdbc.datasource.DataSourceTransactionManager'><property name='dataSource' ref='dataSource'/> </bean> <!--聲明使用注解式事務--> <tx:annotation-driven transaction-manager='transactionManager'/> 只需要在service層方法中執行多條mybatis的mapper并加上注解即可,發生異常則此方法的事務會回滾

標簽: java
相關文章:
主站蜘蛛池模板: 精品久久久久久久久久中文字幕 | 综合久久久久久中文字幕 | 国产精品高清视亚洲精品 | 久久国产一区二区三区 | 亚洲小视频在线播放 | 91无套极品外围在线播放 | 国产日韩精品一区二区三区 | 亚洲美女在线观看亚洲美女 | 日韩特黄毛片 | 久久伊人网站 | a久久99精品久久久久久不 | 亚洲欧美日韩综合二区三区 | 精品久久成人免费第三区 | 美国一级片免费 | 九一精品国产 | 一级做a爰在线就看 | 蕾丝视频永久在线入口香蕉 | 久久草在线视频播放 | 深夜福利视频大全在线观看 | 国产精品亚洲高清一区二区 | 99精品免费 | 2022国产精品自拍 | 国产精品自拍视频 | 成人久久18免费网站游戏 | 亚洲精品久久九九热 | 免费一级视频在线播放 | 香港毛片免费观看 | 一级性片 | 分享一个无毒不卡免费国产 | 最新中文字幕一区二区乱码 | 亚洲乱码国产一区网址 | 免费看欧美成人性色生活片 | 另类视频区第一页 | 精品国产三级a在线观看 | 99视频在线精品免费 | 国产网红自拍 | 国产精品一区二区av | 亚洲精选在线观看 | 热久久在线观看 | 欧美美女视频网站 | 欧美一级日韩一级 |