SpringBoot之@Transactional事务管理简介

一.

在银行转账时如果发生异常可能导致A金钱转出,而B未收到钱的问题,此时需要引入事务管理。
先写一个Bank类:

package com.example.test;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.Table;

@Entity
@Table(name="bank")
public class Bank {

	@Id
	@GeneratedValue
	private int id;
	
	@Column(length=50)
	private String username;
	
	private float balance;

	public int getId() {
		return id;
	}

	public void setId(int id) {
		this.id = id;
	}

	public String getUsername() {
		return username;
	}

	public void setUsername(String username) {
		this.username = username;
	}

	public float getBalance() {
		return balance;
	}

	public void setBalance(float balance) {
		this.balance = balance;
	}
}

然后写一个BankDao接口(使用jpa):

package com.example.test;

import org.springframework.data.jpa.repository.JpaRepository;

public interface BankDao extends JpaRepository<Bank, Integer>{

}

写服务层BankService和BankServiceImpl:

package com.example.service;

public interface BankService {
	
	public void transferAccount(int idA,int idB,float account);
}

package com.example.service;

import javax.annotation.Resource;
import javax.transaction.Transactional;

import org.springframework.stereotype.Service;

import com.example.test.Bank;
import com.example.test.BankDao;

@Service("accountservice")
public class BankServiceImpl implements BankService{

	@Resource
	private BankDao bankDao;
	@Transactional
	public void transferAccount(int idA, int idB, float account) {
		Bank A =bankDao.getOne(idA);
		A.setBalance(A.getBalance()-account);//用户A扣钱
		bankDao.save(A);
		
		Bank B =bankDao.getOne(idB);
		B.setBalance(B.getBalance()+account);//用户B加钱
		bankDao.save(B);
		
	}

}

最后写一个控制类BankController:

package com.example.test;

import javax.annotation.Resource;

import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import com.example.service.BankService;

@RestController
@RequestMapping("/bank")
public class BankController {

	@Resource
	private BankService bankService;
	
	@RequestMapping("/transfer")
	public String transfer() {
		try {
			bankService.transferAccount(1, 2, 50);
			return "OK";
		}catch(Exception e) {
			return "ERROR";
		}
	}
}

二.打开网页,测试:
http://localhost:8888/bank/transfer
(我的application设置了端口为:8888)
看到即成功:
在这里插入图片描述
同时mysql中可以看到金钱的变化:
在这里插入图片描述
为了看到@Transactionnal的效果可以在BankServiceImpl的方法中故意引入异常进行测试。

SpringBoot中,@Transactional注解可以用于实现对事务的管理。在使用SpringBoot与PostgreSQL的项目中,可以使用@Transactional注解来实现事务的回滚操作。当@Transactional注解被应用到方法上时,它会在方法执行前创建或者加入一个事务,并在方法执行完后根据执行情况提交或者回滚事务。这样可以确保在方法执行过程中出现异常时,事务能够正确地回滚。 在使用@Transactional注解时,需要注意以下几点: 1. 该注解只能应用于public修饰的方法上。 2. 默认情况下,Spring会对unchecked异常进行事务回滚,即对RuntimeException及其子类进行回滚操作。如果想对checked异常也进行回滚,可以在注解上指定rollbackFor属性,例如@Transactional(rollbackFor = Exception.class)。 3. 在service层进行try-catch操作时,如果异常被捕获了并且没有抛出,那么事务将不会回滚。如果想要在service层抛出异常并确保事务回滚,可以使用两种方法之一: a. 在catch块中手动设置事务回滚,例如TransactionAspectSupport.currentTransactionStatus().setRollbackOnly()。 b. 在方法上抛出异常,让Spring自动捕获并回滚事务。 总之,通过在SpringBoot项目的方法上使用@Transactional注解,可以便捷地实现对事务的管理,并确保在方法执行过程中出现异常时能够正确地回滚事务。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [SpringBoot事务注解@Transactional](https://blog.csdn.net/qq_42772400/article/details/106136367)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [SpringBoot @Transactional事务回滚实现](https://blog.csdn.net/weixin_44407691/article/details/113094850)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值