transaction學(xué)習(xí)列子

http://www.byteslounge.com/tutorials/spring-transaction-propagation-tutorial

package com.tgb.service;

import javax.annotation.Resource;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Propagation;
import org.springframework.transaction.annotation.Transactional;

@Service(value="sService")
public class StudentService {

    @Resource
    private TeacherService tService;
    
    @Resource
    private JdbcTemplate jdbcTemplate;
    
    @Transactional(propagation = Propagation.REQUIRED)
    public void addStudent(){
        String sql = "insert into student(name) values('st0')";
        jdbcTemplate.execute(sql);
//      try{
//          int a = Integer.parseInt("s");
//      }catch(Exception e){
//          throw new RuntimeException();
//      }
//      tService.addTeacher();
//      tService.addTeacher6();
//      tService.addTeacher1();
        tService.addTeacher3();
//      tService.addTeacher4();
//      tService.addTeacher5();
        
//      throw new RuntimeException();
    }
    
    
    @Transactional(propagation = Propagation.MANDATORY)
    public void addStudent1(){
        String sql = "insert into student(name) values('st1')";
        jdbcTemplate.execute(sql);
    }
    
    @Transactional(propagation = Propagation.NESTED)
    public void addStudent2(){
        String sql = "insert into student(name) values('st2')";
        jdbcTemplate.execute(sql);
        tService.addTeacher2();
//      throw new RuntimeException();
    }
    
    @Transactional(propagation = Propagation.NEVER)
    public void addStudent3(){
        String sql = "insert into student(name) values('st3')";
        jdbcTemplate.execute(sql);
        tService.addTeacher6();
        throw new RuntimeException();
    }
    
    @Transactional(propagation = Propagation.NOT_SUPPORTED)
    public void addStudent4(){
        String sql = "insert into student(name) values('st4')";
        jdbcTemplate.execute(sql);
        tService.addTeacher4();
        throw new RuntimeException();
    }
    
    @Transactional(propagation = Propagation.REQUIRES_NEW)
    public void addStudent5(){
        String sql = "insert into student(name) values('st5')";
        jdbcTemplate.execute(sql);
        tService.addTeacher5();
        throw new RuntimeException();
    }
    
    @Transactional(propagation = Propagation.SUPPORTS)
    public void addStudent6(){
        String sql = "insert into student(name) values('st6')";
        jdbcTemplate.execute(sql);
        tService.addTeacher6();
        throw new RuntimeException();
    }


    public TeacherService gettService() {
        return tService;
    }


    public void settService(TeacherService tService) {
        this.tService = tService;
    }
}

package com.tgb.service;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Propagation;
import org.springframework.transaction.annotation.Transactional;

@Service
public class TeacherService {

    
    @Autowired
    private JdbcTemplate jdbcTemplate;
    
    /**
     * REQUIRED
     */
    @Transactional(propagation = Propagation.REQUIRED)
    public void addTeacher(){
        String sql = "insert into teacher(name) values ('t0')";
        jdbcTemplate.execute(sql);
//      throw new RuntimeException();
    }
    
    
    /**
     * MANDATORY
     */
    @Transactional(propagation = Propagation.MANDATORY)
    public void addTeacher1(){
        String sql = "insert into teacher(name) values ('t1')";
        jdbcTemplate.execute(sql);
    }
    
    
    /**
     * NESTED
     */
    @Transactional(propagation = Propagation.NESTED)
    public void addTeacher2(){
        String sql = "insert into teacher(name) values ('t2')";
        jdbcTemplate.execute(sql);
    }
    
    
    /**
     * NEVER
     */
    @Transactional(propagation = Propagation.NEVER)
    public void addTeacher3(){
        String sql = "insert into teacher(name) values ('t3')";
        jdbcTemplate.execute(sql);
    }
    
    
    /**
     * NOT_SUPPORTED
     */
    @Transactional(propagation = Propagation.NOT_SUPPORTED)
    public void addTeacher4(){
        String sql = "insert into teacher(name) values ('t4')";
        jdbcTemplate.execute(sql);
        throw new RuntimeException();
    }
    
    
    /**
     * REQUIRES_NEW
     */
    @Transactional(propagation = Propagation.REQUIRES_NEW)
    public void addTeacher5(){
        String sql = "insert into teacher(name) values ('t5')";
        jdbcTemplate.execute(sql);
    }
    
    
    /**
     * SUPPORTS
     */
    @Transactional(propagation = Propagation.SUPPORTS)
    public void addTeacher6(){
        String sql = "insert into teacher(name) values ('t6')";
        jdbcTemplate.execute(sql);
    }
}

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 136,564評論 19 139
  • 前些日子從@張鑫旭微博處得一份推薦(Front-end-tutorial),號稱最全的資源教程-前端涉及的所有知識...
    谷子多閱讀 4,492評論 0 44
  • 昨晚寫了一些文字,發(fā)布操作的時候,居然沒有成功?許是沒有保存,又恰巧斷網(wǎng)了。所以,什么都沒了。在生活中,我們常常也...
    青柳青青閱讀 101評論 4 12
  • 【搜索分區(qū)】 《知識點》 Input這種帶有功能的東西千萬不要加超鏈接。因為會發(fā)生功能沖突,超鏈接本身也是一個功能...
    黑色的夜閱讀 194評論 0 0
  • 荒郊獵小鹿 打死包白茅 少女春心動 獵人送上前 小樹砍柴燒 小鹿死荒郊 白茅捆扎好 佳人請收好 請你慢慢來 沒碰圍...
    黃耶魯閱讀 395評論 0 8

友情鏈接更多精彩內(nèi)容