当前位置:   article > 正文

面试官:Spring@Transactional注解在什么情况下事务不生效?_为什么方法上面没加@transactional 事务也是开启

为什么方法上面没加@transactional 事务也是开启

这篇笔记来学习一下使用Spring框架的时候,@Transactional注解标注的方法在什么情况下事务不会生效。

我们可以写一个demo项目,

引入以下依赖

  1. <dependencies>
  2. <dependency>
  3. <groupId>mysql</groupId>
  4. <artifactId>mysql-connector-java</artifactId>
  5. <version>5.1.6</version>
  6. </dependency>
  7. <dependency>
  8. <groupId>org.springframework</groupId>
  9. <artifactId>spring-jdbc</artifactId>
  10. <version>5.2.8.RELEASE</version>
  11. </dependency>
  12. <dependency>
  13. <groupId>org.springframework</groupId>
  14. <artifactId>spring-context</artifactId>
  15. <version>5.2.8.RELEASE</version>
  16. </dependency>
  17. </dependencies>

项目的目录结构如下:

我们新建一个user表,之后会用上

  1. CREATE TABLE `tb_user` (
  2. `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
  3. `name` varchar(255) NOT NULL DEFAULT '',
  4. `age` int(11) NOT NULL DEFAULT '0',
  5. PRIMARY KEY (`id`)
  6. ) ENGINE=InnoDB AUTO_INCREMENT=50 DEFAULT CHARSET=utf8

然后我们需要在 site.nemo.entity 包里面定义一个User类:

  1. package site.nemo.entity;
  2. public class User {
  3. private Integer id;
  4. private String name;
  5. private Integer age;
  6. public Integer getId() {
  7. return id;
  8. }
  9. public void setId(Integer id) {
  10. this.id = id;
  11. }
  12. public String getName() {
  13. return name;
  14. }
  15. public void setName(String name) {
  16. this.name = name;
  17. }
  18. public Integer getAge() {
  19. return age;
  20. }
  21. public void setAge(Integer age) {
  22. this.age = age;
  23. }
  24. @Override
  25. public String toString() {
  26. return "User{" +
  27. "id=" + id +
  28. ", name='" + name + '\'' +
  29. ", age=" + age +
  30. '}';
  31. }
  32. }

然后我们还需要一个Dao,来操作user表。在 site.nemo.dao 包下新建一个UserDao类:

  1. @Repository
  2. public class UserDao {
  3. @Autowired
  4. private JdbcTemplate jdbcTemplate;
  5. public void save(User user) {
  6. jdbcTemplate.update("insert into tb_user (name, age) values (?, ?)", user.getName(), user.getAge());
  7. }
  8. }

然后我们还需要对jdbc的数据源进行一些配置,在 site.nemo.configuration 包里面新建一个配置类:

  1. @Configuration
  2. @ComponentScan(basePackages = {"site.nemo.service", "site.nemo.dao"})
  3. public class TransactionConfiguration {
  4. @Bean
  5. public JdbcTemplate jdbcTemplate() {
  6. return new JdbcTemplate(dataSource());
  7. }
  8. @Bean
  9. public DataSource dataSource() {
  10. DriverManagerDataSource dataSource = new DriverManagerDataSource();
  11. dataSource.setDriverClassName("com.mysql.jdbc.Driver");
  12. dataSource.setUrl("jdbc:mysql://xxx.xxx.xxx.xxx:3306/mytestdb?characterEncoding=utf8");
  13. dataSource.setUsername("xxxx");
  14. dataSource.setPassword("xxxx");
  15. return dataSource;
  16. }
  17. }

最后我们在 site.nemo.service 里面新建一个UserService:

  1. @Service
  2. public class UserService {
  3. @Autowired
  4. private UserDao userDao;
  5. }

我们下面开始分析几个@Transactional没有起作用的原因

原因一:没有开启事务管理

我们给 UserService 添加一个方法,如下所示。

  1. @Transactional
  2. public void save1() {
  3. User user &#
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/IT小白/article/detail/153704
推荐阅读
相关标签
  

闽ICP备14008679号