当前位置: 首页 > news >正文

成都建设银行分行招聘网站天安云谷网站建设

成都建设银行分行招聘网站,天安云谷网站建设,wordpress 主题开发,重庆网站制概念 在MySQL中介绍过,当同一时间出现一起读写数据的情况,可能会导致最终的结果出错,因此可以使用事务来提高隔离级别 而Spring中也可以实现事务 手动添加事务 使用SpringBoot中的DataSourceTransactionManager对象可以获取事务&#xff0…

概念

在MySQL中介绍过,当同一时间出现一起读写数据的情况,可能会导致最终的结果出错,因此可以使用事务来提高隔离级别
而Spring中也可以实现事务

手动添加事务

使用SpringBoot中的DataSourceTransactionManager对象可以获取事务,提交事务,回滚事务

TransactionDefinition是事务的属性,在获取事务时需要传入这个参数

而TransactionStatus则是在获取事务时获取的对象,最终回滚时使用

@RestController
@RequestMapping("url")
public class 实现类 {@Autowiredprivate DataSourceTransactionManager transactionManager;@Autowiredprivate TransactionDefinition transactionDefinition;@RequestMapping("url")public 相关方法() {//开启事务TransactionStatus transactionStatus =transactionManager.getTransaction(transactionDefinition);//处理事务//回滚事务transactionManager.rollback(transactionStatus);}

例如:

@RestController
@RequestMapping("/user")
public class UserController {@Autowiredprivate UserService userService;@Autowiredprivate DataSourceTransactionManager transactionManager;@Autowiredprivate TransactionDefinition transactionDefinition;@RequestMapping("/add")public int add(UserInfo userInfo) {if (userInfo == null || !StringUtils.hasLength(userInfo.getUsername()) ||!StringUtils.hasLength(userInfo.getPassword())) {return 0;}//开启事务TransactionStatus transactionStatus =transactionManager.getTransaction(transactionDefinition);int result = userService.add(userInfo);//回滚事务transactionManager.rollback(transactionStatus);return result;}
}

在页面中,传输了参数username = 1, password = 1
但是在数据库中,并没有出现这行数据
在这里插入图片描述

自动添加事务

使用@Transactional注解可以快速添加事务

@Transactional
@RequestMapping("/insert")
public Integer insert(UserInfo userInfo) {if (userInfo == null || !StringUtils.hasLength(userInfo.getUsername()) ||!StringUtils.hasLength(userInfo.getPassword())) {return 0;}int result = userService.add(userInfo);}return result;
}

如果没有异常,那么会自动提交事务,如果有异常,事务会进行回滚

例如:在类中添加空指针异常
如果没有添加@Transactional那么在异常出现前数据已经上传到数据库

@RequestMapping("/insert")
public Integer insert(UserInfo userInfo) {if (userInfo == null || !StringUtils.hasLength(userInfo.getUsername()) ||!StringUtils.hasLength(userInfo.getPassword())) {return 0;}int result = userService.add(userInfo);int num = 1 / 0;return result;
}

在这里插入图片描述
在这里插入图片描述
而加了@Transactional注解,就可以自动回滚事务,数据库中就没有这行数据了
在这里插入图片描述
在这里插入图片描述
而如果我们添加了try,catch语句,spring就不会感知到异常的存在了,也就不会进行事务的回滚了

@Transactional //声明式事务(没有错误自动提交)
@RequestMapping("/insert")
public Integer insert(UserInfo userInfo) {if (userInfo == null || !StringUtils.hasLength(userInfo.getUsername()) ||!StringUtils.hasLength(userInfo.getPassword())) {return 0;}int result = userService.add(userInfo);try{int num = 1 / 0;} catch (Exception e){e.printStackTrace()}return result;
}

在这里插入图片描述
在这里插入图片描述
如果我们还想要事务进行自动回滚,那么可以使用throw将异常抛出,这样spring就能再次感知到异常的存在了

@Transactional //声明式事务(没有错误自动提交)
@RequestMapping("/insert")
public Integer insert(UserInfo userInfo) {if (userInfo == null || !StringUtils.hasLength(userInfo.getUsername()) ||!StringUtils.hasLength(userInfo.getPassword())) {return 0;}int result = userService.add(userInfo);try{int num = 10 / 0;} catch (Exception e){e.printStackTrace();throw e;}return result;
}

在这里插入图片描述
在这里插入图片描述

如果不想要页面出现报错信息,那么可以不添加throw语句,而是手动回滚事务

@Transactional //声明式事务(没有错误自动提交)
@RequestMapping("/insert")
public Integer insert(UserInfo userInfo) {if (userInfo == null || !StringUtils.hasLength(userInfo.getUsername()) ||!StringUtils.hasLength(userInfo.getPassword())) {return 0;}int result = userService.add(userInfo);try{int num = 10 / 0;} catch (Exception e){e.printStackTrace();TransactionAspectSupport.currentTransactionStatus().setRollbackOnly()}return result;
}

在这里插入图片描述
在这里插入图片描述

事务隔离级别设置

当不同事务同时对数据库进行数据操作,就会出现问题,因此可以针对不同的情景设置不同的隔离级别
在这里插入图片描述

在@Transactional注解中可以设置事务的隔离级别
在这里插入图片描述

代码含义问题
Isolation.DEFAULT默认级别 以数据库隔离级别执行
Isolation.READ_UNCOMMITTED读未提交 可以读未提交数据存在脏读问题
Isolation.READ_COMMITED读已提交 只能读到已经提交事务存在不可重复读问题
Isolation.REPEATABLE_READ可重复读存在幻读问题
Isolation.SERIALIZABLE串行化性能低

事务传播机制

在项目中会存在多个方法链式调用,而每一个方法都有可能存在事务,因此存在不同的事物传播机制
在这里插入图片描述
分别有如下几种事物传播级别:

代码说明
Propagation.REQUIRED(默认)如果当前存在事务则加入事务,都则创建一个事务
Propagation.SUPPORTS如果当前存在事务就加入事务,否则就以非事务方式运行
Propagation.MANDATORY如果当前存在事务就加入事务,否则抛出异常
Propagation.REQUIRES_NEW不管当前有没有事务,都创建并使用新事务
Propagation.NOT_SUPPORTED不管当前有没有事务,都以非事务方式运行
Propagation.NEVER以非事务形式运行,如果当前存在事务就抛出异常
Propagation.NESTED如果当前存在事务,则创建一个事务作为当前事务的嵌套事务运行,当作REQUIRED
http://www.yayakq.cn/news/61395/

相关文章:

  • 建设网站的企业费用专门为98k做的网站
  • 网站快速建设入门教程wordpress 注册码授权
  • 顺德营销网站设计wordpress 门户主题
  • dedecms 做影网站白杨seo
  • 做网站应聘平台wordpress继续阅读插件
  • 网站建设合同技术开发合同范本东莞互联网
  • 建网站那个网最好公司网站的功能
  • wordpress图片主题演示济南网络优化推广公司哪家好
  • 中国建设部官方网站监理转注册建设 静态网站
  • 西安网站建设设计的好公司排名三沙网站设计公司
  • 网站建站公司哪家价钱合理织梦网站怎样做锚文本
  • 山东省建设厅官方网站怎么样优秀的网站有哪些内容
  • 杭州做网站外包公司哪家好公司做网站费用计入什么科目
  • 怎么查看网站打开速度网易企业邮箱客户端下载
  • 开封网站推广线上渠道推广怎么做
  • 亳州企业网站建设北海网站制作公司
  • 网站开发绩效考核wordpress 4.7.5
  • 网站建设与管理报告书直播app开发公司排名
  • 哪个网站做头像比较好湖南智能网站建设哪里好
  • wordpress网站字体大小一个企业可以做几个网站
  • 亚马逊网站建设案例分析网站是哪家公司做的
  • 深圳工程造价建设信息网站html5网站案例
  • 哈尔滨建设网站公司大数据智能营销系统
  • 网站自适应尺寸商城首页设计
  • 网站死链如何处理玩游戏的网页
  • 手机网站触摸版网站建设购买数据库的流程图
  • 建设银行网站首页是多少平面设计模板素材网站
  • 男女做暖暖免费网站wordpress 插件开发教程
  • 顺德网站建设多少钱工业产品设计包括哪些
  • 宁夏网站建设电话汉服销售网站建设