@Transactional 何时进行事务回滚的说明

1.何时进行事务回滚
当被注解的方法抛出异常时进行事务回滚
下面代码,一次提交两个user对象,一个是已经存在的,打印出了异常信息,控制台也输出了“2222222.。。”但还是插入了另外一个用户,因为捕获到的异常没有抛出。

 /**
     * 插入新用户
     * @param user
     */
    @Override
    @Transactional
     public void insertUser(User user){
        try {
            User user1=new User();
            user1.setUserId(15);
            user1.setUserName("c2");
            user1.setUserPassword("3456");
            userDao.insertUser(user1);
            userDao.insertUser(user);
        }
        catch (Exception e){
            for(int i=0;i<100;i++) {
                System.out.println("2");
            }
        }
     }

下面的代码成功进行了事务回滚,第一条数据因为在插入第二条数据时抛出异常而进行了事务回滚,所以没有成功插入数据库。

 /**
     * 插入新用户
     * @param user
     */
    @Override
    @Transactional
     public void insertUser(User user){
        try {
            User user1=new User();
            user1.setUserId(15);
            user1.setUserName("c2");
            user1.setUserPassword("3456");
            userDao.insertUser(user1);
            userDao.insertUser(user);
        }
        catch (Exception e){
            throw e;
        }
     }

你可能感兴趣的:(spring,springMVC,mybatis)