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

大连 建网站做网站制作要多少费用

大连 建网站,做网站制作要多少费用,马洪旭 做的网站大学,外贸公司代理注册为什么存在数据源切换和食物时效问题? 由于业务数据来源不同 需要配置多个数据源来进行数据的查询 编辑等操作 这一切换业务对数据的一致性要求很高那就要保证ACID啦 也就是数据的有效性 要么是成功的 要么是失败的。 数据源切换采用mybatisplus支持 多数据源配置&a…

为什么存在数据源切换和食物时效问题?
由于业务数据来源不同 需要配置多个数据源来进行数据的查询 编辑等操作 这一切换业务对数据的一致性要求很高那就要保证ACID啦 也就是数据的有效性 要么是成功的 要么是失败的。
数据源切换采用mybatisplus支持
多数据源配置:oracle和mysql的数据类型

 spring:datasource:dynamic:primary: master #设置默认的数据源或者数据源组,默认值即为masterdatasource:master:username: rootpassword: rootdriver-class-name: com.mysql.cj.jdbc.Driverurl: jdbc:mysql://10.20.204.130:3306/user?useUnicode=true&characterEncoding=utf-8&useSSL=false&serverTimezone=Asia/Shanghaicoloan:username: rootpassword: rootdriver-class-name: oracle.jdbc.driver.OracleDriverurl: jdbc:oracle:thin:@10.20.201.173:1521:rthhhhhdb

由于是公司业务 故大致做一些特殊类名称的改改写
1:方法的入口

@RestController
public class testContorller {@AutowiredtestService testService;@PostMapping("/queryBankInfoList")public String queryBankInfoList(){List<CoTodoTask> coTodoTasks = testService.queryBankInfoList();return JSON.toJSONString(JSON.toJSONString(coTodoTasks));}
}

service接口定义

public interface testService extends IService<CoTodoTask> {List<Task> queryBankInfoList();}

实现service的核心类

Service
@DS("coloan")
public class testServiceImpl extends ServiceImpl<TaskMapper, Task> implements testService {@AutowiredUserService userService;@AutowiredTaskMapper TaskMapper;@Transactional(rollbackFor = Exception.class)@Overridepublic List<Task> queryBankInfoList() {//  用户表在MySQLResult result = userService.userInfo(117);QueryWrapper<Task> wrapper = new QueryWrapper<>();wrapper.isNotNull("id");//  任务表在Oracle中List<Task> Tasks = TaskMapper.selectList(wrapper);return Tasks;}
}

默认主数据原 这里可以不用注解指定 因为配置文件默认的主数据原就是master 这里我加上了

@Service
@DS("master")
public class UserServiceImpl implements UserService {@Overridepublic Result userInfo(Integer userId) {User user = userMapper.selectUser(userId, null);return new Result().setData(userVO);}
}

运行调试 发现一下问题
Error querying database. Cause: java.sql.SQLSyntaxErrorException: ORA-00942: 表或视图不存在
注意观察信息
userService的数据库应该是master,但是却是coloan的,导致代码报500,也就是说@DS切换数据源没有起作用
初步结论
多数据源失效,然后去掉事务发现切换正常 在于这样的切换失去了事务控制的行为。
通过下面的方式解决

@Transactional(rollbackFor = Exception.class, propagation = Propagation.REQUIRED)@Overridepublic List<CoTodoTask> queryBankInfoList() {...}

通过上述的修改 数据源能正常的切换 并且可控事务
2:什么是事务的传播特性
当事务方法被另一个事务方法调用时,必须指定事务应该如何传播。例如:方法可能继续在现有事务中运行,也可能开启一个新事务,并在自己的事务中运行。
事务的传播行为可以由传播属性指定。Spring定义了7种类传播行为。
在这里插入图片描述
演示事务的传播特性
ps:这里借用一下我之前看到的一篇关于事务传播特性特别棒的几张图片。
1:大小事务传播特性都是REQUIRED

@Transactional(propagation = Propagation.REQUIRED)public void multiTransaction() {}@Transactional(propagation = Propagation.REQUIRED)public void updateBook() {}@Transactional(propagation=Propagation.REQUIRED)public void updateUser() {}

传播流程:
在这里插入图片描述
大小事务传播特性都是REQUIRES_NEW
在这里插入图片描述
传播流程:在这里插入图片描述
3:大事务是REQUIRED,小1REQUIRED,小2REQUIRES_NEW
在这里插入图片描述
传播流程:
在这里插入图片描述
总结:
事务会导致多数据源失效,这个大家一定要记清
一定要明白事务的传播特性,开发中其实常用的就只有REQUIRED和REQUIRES_NEW,大家只要把这两个搞明白,就能应对绝大数的问题。
以上是mybatis-plus之数据源切换事务失效问题 关注老哥带你上高速 。。。。。。。。。
在这里插入图片描述

http://www.yayakq.cn/news/432810/

相关文章:

  • 互动型网站成功例子网站幻灯片 字段
  • 2万元自己动手装修房子潍坊网站seo
  • 网站搭建技术方案商务网站前台模板
  • 最好在线网站建设怎么注册一个电商平台
  • 怎么免费制作企业网站中文域名指向同一个网站
  • 如何开发网站建设业务网页加速器怎么用
  • wordpress 小刀娱乐产品优化是什么意思
  • 免费稳定的网站空间网站设计编辑
  • 网页代理app哪里有整站优化
  • dede怎么做视频网站ui用户界面设计
  • 仿西部数码网站wordpress搬家菜单
  • 如何做网站平台关注做个app需要多少费用
  • 特价锦州网站建设阿里国际站网站建设
  • 苏州市吴江区住房和城乡建设局网站衡水企业网站建设报价
  • 我要建设一个网站宝贝做网站
  • 学校类网站建设的分析Wordpress仿制网站
  • 招投标中网站建设评分标准自己做网站可以揽业务吗
  • 学网页制作的好处seo点击软件排名优化
  • 官方网站怎么写网站建设宝典
  • 腾讯云网站免费建设广州网站订制开发
  • 做网站什么系统好wordpress哪个版本
  • 外贸网站做流量体彩足球竞彩比赛结果韩国比分
  • 网站建设前言和背景佛山网页网站设计
  • 兰州市城市建设设计院网站济南网站建设全包
  • 黑龙江期刊网站制作模板网站的建设
  • 南昌网站建设公司渠道陆家网站建设
  • vue cms 网站开发华为云和wordpress
  • 网站后wordpress文章编辑页面j建设银行信用卡网站
  • 徐州企业免费建站禁止wordpress自动更新
  • 关于公路建设的网站宁波seo营销平台