@Transactional注解不生效

在Spring中,@Transactional注解失效,通過(guò)網(wǎng)上搜索,基本可以找到如下3個(gè)原因:

1、在同一個(gè)類中,沒有@Transactional注解的方法去調(diào)用有@Transactional注解

2、@Transactional注解修飾的方法不是public的

3、拋出的異常為checked類型

但今天比較倒霉了,@Transactional失效,都不是以上3個(gè)原因。
還原一下當(dāng)時(shí)的情形:

配置文件application.properties:

spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.url=jdbc:mysql://127.0.0.1:3306/dbgirl?useUnicode=true&characterEncoding=UTF-8
spring.datasource.username=root
spring.datasource.password=123456
spring.jpa.hibernate.ddl-auto=update
spring.jpa.database-platform=org.hibernate.dialect.MySQL5Dialect

User實(shí)體類:

@Entity
@Table(name = "users")
public class User {

    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    private Long id;

    @Column(unique = true)
    private String name;

    private String company;

    // 略去getter,setter 
}

Service方法:

@Component
public class DemoService {

    @Autowired
    UserDao userDao;

    @Autowired
    OperationLogDao operationLogDao;

    @Transactional
    public void addUser(String name){
        OperationLog log = new OperationLog();
        log.setContent("create user:" + name);
        operationLogDao.save(log);

        User user = new User();
        user.setName(name);
        userDao.save(user);
    }

}

本來(lái)想的很好,利用jpa自動(dòng)生成數(shù)據(jù)庫(kù)表結(jié)構(gòu),方便向users表插入記錄。當(dāng)重復(fù)插入同一個(gè)name的User時(shí),會(huì)報(bào)Duplicate entry 的錯(cuò)誤,然后導(dǎo)致回滾,但結(jié)果并沒有。
后來(lái)搜了好久,才發(fā)現(xiàn),mmp!

數(shù)據(jù)庫(kù)里表的引擎是MyISAM,不支持事務(wù)處理。。關(guān)鍵在于application.properties中這一行配置:

spring.jpa.database-platform=org.hibernate.dialect.MySQL5Dialect

將其修改如下

spring.jpa.database-platform=org.hibernate.dialect.MySQL5InnoDBDialect

再重新生成表后,引擎變?yōu)镮nnodb,再調(diào)用addUser方法,報(bào)錯(cuò)以后,事務(wù)終于回滾了

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

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

  • Spring Boot 參考指南 介紹 轉(zhuǎn)載自:https://www.gitbook.com/book/qbgb...
    毛宇鵬閱讀 47,272評(píng)論 6 342
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 136,554評(píng)論 19 139
  • 青田小可愛們: 好久不見!好想你們啊。收到了你們的來(lái)信,不能一一回信真的很抱歉啊。記得9.18...
    咦雙眼皮董燕兒閱讀 823評(píng)論 0 1
  • listen()函數(shù)僅有TCP服務(wù)器調(diào)用 #include int listen(int sockfd, int ...
    狗尾巴草敗了閱讀 869評(píng)論 0 0
  • 酒過(guò)三巡人煙散, 獨(dú)處深山覓乾坤。 葉落孤空跡難尋, 驚聞廟中木魚聲。
    老林9911閱讀 206評(píng)論 0 0

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