Pengecualian yang disemak: Pengecualian di bawah Pengecualian kecuali RuntimeException
Pengecualian tidak disemak: RuntimeException dan subkelas serta ralatnya (Ralat)
属性 | 类型 | 描述 |
---|---|---|
value | String | 可选的限定描述符,指定使用的事务管理器 |
propagation | enum: Propagation | 可选的事务传播行为设置 |
isolation | enum: Isolation | 可选的事务隔离级别设置 |
readOnly | boolean | 读写或只读事务,默认读写 |
timeout | int (in seconds granularity) | 事务超时时间设置 |
rollbackFor | Class对象数组,必须继承自Throwable | 导致事务回滚的异常类数组 |
rollbackForClassName | 类名数组,必须继承自Throwable | 导致事务回滚的异常类名字数组 |
noRollbackFor | Class对象数组,必须继承自Throwable | 不会导致事务回滚的异常类数组 |
noRollbackForClassName | 类名数组,必须继承自Throwable | 不会导致事务回滚的异常类名字数 |
Apabila menggunakan anotasi @Transaction , pemalam spesifikasi kod Alibaba akan mengingatkan anda bahawa anda perlu menentukan rollbackUntuk memaparkan rollback
Secara lalai, rangka kerja Spring menggunakan Secara lalai, apabila @Transaction mengendalikan urus niaga, urus niaga akan ditarik balik hanya apabila membuang pengecualian masa jalan dan pengecualian tidak ditandai. Iaitu, apabila contoh RuntimeException atau subkelasnya dilemparkan, Pengecualian yang ditandakan yang dibuang daripada kaedah urus niaga tidak akan ditandakan untuk rollback transaksi.
Untuk membuat pengembalian pengecualian yang ditandakan: Tambahkan @Transactional(rollbackOn=Exception.class)
sebelum keseluruhan kaedah untuk membuat pengecualian yang tidak ditanda bukan rollback: @Transactional(dontRollbackOn=RunTimeException.class)
Kaedah yang tidak memerlukan pengurusan transaksi (pertanyaan sahaja): @Transactional(propagation=Propagation.NOT_SUPPORTED)
Nota :
Jika pengecualian cuba ditangkap, urus niaga tidak akan ditarik balik Jika anda mahu urus niaga itu ditarik balik, anda mesti membuangnya semula try{}catch{throw Exception}
.
Pasukan Spring mengesyorkan menggunakan anotasi @Transactional pada kelas tertentu (atau kaedah kelas), dan bukannya pada mana-mana antara muka yang kelas ingin laksanakan. Anda juga boleh menggunakan anotasi @Transactional pada antara muka, tetapi dalam kes ini ia hanya akan berkuat kuasa jika anda perlu menyediakan proksi berasaskan antara muka
Kaedah yang dikenal pasti oleh @Anotasi transaksi disyorkan semudah mungkin. Terutama untuk kaedah transaksi dengan kunci, sebaiknya jangan masukkannya ke dalam transaksi jika boleh dielakkan. Operasi pertanyaan pangkalan data biasa boleh diletakkan di hadapan transaksi, dan operasi seperti penambahan, pemadaman dan pengubahsuaian boleh diletakkan dalam transaksi
@Slf4j @Service public class MemberService { @Autowired private MemberMapper memberMapper; @Transactional public Integer insert(MemberEntity memberEntity) { Integer insertResult = 0; try { insertResult = memberMapper.save(memberEntity); log.info("insertResult:{}", insertResult); int result = 1 / memberEntity.getAge(); } catch (Exception e) { log.error("errorMsg:{}", e.getMessage()); //回滚 TransactionAspectSupport.currentTransactionStatus().setRollbackOnly(); } return insertResult; } }
seperti dalam kod Merah superskrip, jika anda tidak menulisnya, transaksi tidak akan ditarik balik. Oleh kerana urus niaga ditangkap oleh tangkapan, transaksi hanya boleh digulung semula secara manual.
Atas ialah kandungan terperinci Cara menggunakan Java @Transactional untuk menentukan syarat rollback. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!