《springcloud alibaba》 四 seata安装以及使用

目录

  • 准备
  • 调整db配置
    • 准备创建数据库
  • seata配置nacos
    • 配置confi.txt
    • 下载向nacos推送配置的脚本
  • 启动seata
  • 新建项目
  • order-seata项目 订单项目
    • 数据库脚本
    • pom.xml
    • application.yml
    • 启动类
    • 实体类
    • dao类
    • service类
    • controller类
    • feign类
    • mapper类
  • stock-seata 库存项目
    • 数据库脚本
    • pom.xml
    • application.yml
    • 启动类
    • 实体类
    • dao类
    • service类
    • controller类
    • mapper类
  • 测试
  • 特殊情况
  • 分布式事务
    • order-seata项目变动
      • pom.xml
      • application.yml
      • controller
    • stock-seata项目变动
      • pom.xml
      • application.yml
    • 脚本
    • 效果
  • 分布式事务原理
    • nacos配置问题
    • seata的几个表都是什么情况

准备

名称版本
Nacos1.4.5
seata1.4.0
alibabacloud2.2.5.RELEASE
  • 本博客版本

seata官网地址
seata安装包下载
在这里插入图片描述

  • 没有linux服务器,可本地搭建玩一下
  • 注意alibaba版本跟seata版本一定要严格控制,不然会出现一些奇奇怪怪的问题

默认数据存储分为2钟,一种是存在bin目录下的root.data文件里面,还有一种是db方式,本文使用db模式

调整db配置

  • 注意mysql数据库的版本得5.7以上。-
  • 修改配置文件之前,别慌,先copy一遍再说,养成好习惯
    在这里插入图片描述
  • 调整模式为db, 修改db对应的配置

准备创建数据库

在这里插入图片描述
mysql脚本下载地址
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

  • 先把整个项目下载,然后到这个目录下,找到mysql.sql

seata配置nacos

在这里插入图片描述

  • 先备份一下配置文件
    在这里插入图片描述
  • 删除其他没有用的配置,调整一下配置

配置confi.txt

到之前下载好的依赖包中copy对应的config.txt文件,放到seata目录下
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

  • 修改存储类型
    在这里插入图片描述
  • 调整为自己对应的url地址,以及账号和密码

下载向nacos推送配置的脚本

在这里插入图片描述

  • 将该脚本移动到seata的conf配置下
    在这里插入图片描述
sh nacos-config.sh -h 127.0.0.1 -p 8848 -g SEATA_GROUP -t seata -u nacos -w nacos
# h: nacos服务ip.
# p: nacos服务端口号.
# g: 想要的分组信息.
# t: 第一步新建的命名空间.
# u: nacos登录名.
# w: nacos登录密码

如果是本地没有做任务的修改,直接运行就行
在这里插入图片描述

  • 大概运行5分钟左右
    在这里插入图片描述
  • 很奇葩的设计,搞不懂为什么不单独弄一个文件来存储所有的内容,而是key value的方式,看起来很乱,建议单独创建一个seata的命令空间用来存储这些配置

启动seata

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

  • window启动用bat文件
    在这里插入图片描述
  • 可以看出默认端口为8091,也可以自定义
    在这里插入图片描述
  • 在服务列表中,就可以看到多了一个seata-server的服务
  • 因为window版本,不好演示集群方式,所以我这里的集群数量是1

新建项目

在这里插入图片描述
在之前的基础上新增一个seata项目
在这里插入图片描述

  • 注意,新增后,该项目是没有蓝点的
    在这里插入图片描述

  • 添加+号,解决蓝点问题
    在这里插入图片描述

  • 自己手动补一下seata这个目录

  • 创建模块order-seata和stock-seata

order-seata项目 订单项目

在这里插入图片描述

  • 新增这两个项目

在这里插入图片描述

  • 库存项目的结构

数据库脚本

create database seata_order;
use seata_order;CREATE TABLE `order_tbl` (`id` int(11) NOT NULL AUTO_INCREMENT,`product_id` varchar(200) DEFAULT NULL,`total_amount` decimal(10,3) DEFAULT NULL,`statu` int(11) DEFAULT NULL,PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=9 DEFAULT CHARSET=utf8
  • 新增数据库

pom.xml

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd"><modelVersion>4.0.0</modelVersion><parent><groupId>com.lcs.springcloud</groupId><artifactId>springcloudalibaba</artifactId><version>0.0.1-SNAPSHOT</version></parent><artifactId>order-nacos</artifactId><packaging>jar</packaging><dependencies><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>3.8.1</version><scope>test</scope></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId><exclusions><exclusion><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-ribbon</artifactId></exclusion></exclusions></dependency><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-sentinel</artifactId></dependency><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-openfeign</artifactId><exclusions><exclusion><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-netflix-ribbon</artifactId></exclusion></exclusions></dependency><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-loadbalancer</artifactId></dependency></dependencies><build><finalName>order</finalName></build>
</project>

application.yml

server:port: 8190spring:application:name: order-seatacloud:nacos:discovery:namespace: publicserver-addr: localhost:8848username: nacospassword: nacosdatasource:type: com.alibaba.druid.pool.DruidDataSourcedruid:db-type: mysqldriver-class-name: com.mysql.jdbc.Driverurl: jdbc:mysql://192.168.10.108:3306/seata_order?useUnicode=true&characterEncoding=utf-8&allowMultiQueries=true&useSSL=false&serverTimezone=Asia/Shanghai&allowPublicKeyRetrieval=true&useCursorFetch=trueusername: rootpassword: 12312312
mybatis:mapper-locations: classpath:mapper/*.xml

启动类

package com.lcs.springcloud;import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.openfeign.EnableFeignClients;@SpringBootApplication
@MapperScan("com.lcs.springcloud.dao")
@EnableFeignClients
public class OrderSeataApplication {public static void main(String[] args) {SpringApplication.run(OrderSeataApplication.class);}
}

实体类

package com.lcs.springcloud.entity;import java.math.BigDecimal;public class OrderTbl {private Integer id;private String product_id;private BigDecimal total_amount;private Integer statu;public OrderTbl() {}public Integer getId() {return id;}public void setId(Integer id) {this.id = id;}public String getProduct_id() {return product_id;}public void setProduct_id(String product_id) {this.product_id = product_id;}public BigDecimal getTotal_amount() {return total_amount;}public void setTotal_amount(BigDecimal total_amount) {this.total_amount = total_amount;}public Integer getStatu() {return statu;}public void setStatu(Integer statu) {this.statu = statu;}@Overridepublic String toString() {return "OrderTbl{" +"id=" + id +", product_id='" + product_id + '\'' +", total_amount=" + total_amount +", statu=" + statu +'}';}
}

dao类

package com.lcs.springcloud.dao;import com.lcs.springcloud.entity.OrderTbl;
import org.springframework.stereotype.Repository;@Repository
public interface OrderDao {void insert(OrderTbl orderTbl);
}

service类

package com.lcs.springcloud.service;import com.lcs.springcloud.dao.OrderDao;
import com.lcs.springcloud.entity.OrderTbl;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;@Service
public class OrderService {@AutowiredOrderDao orderDao;public void insert(OrderTbl orderTbl) {orderDao.insert(orderTbl);}
}

controller类

package com.lcs.springcloud.controller;import com.lcs.springcloud.entity.OrderTbl;
import com.lcs.springcloud.feign.StockOpenFeign;
import com.lcs.springcloud.service.OrderService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;import java.math.BigDecimal;@RestController
@RequestMapping("/order")
public class OrderController {@AutowiredOrderService orderService;@AutowiredStockOpenFeign stockOpenFeign;@RequestMapping("/add")public String add(){OrderTbl orderTbl = new OrderTbl();orderTbl.setProduct_id("10");orderTbl.setTotal_amount(new BigDecimal(3000));orderTbl.setStatu(0);orderService.insert(orderTbl);String reduct = stockOpenFeign.reduct(orderTbl.getProduct_id());return "add order "+reduct;}
}

feign类

package com.lcs.springcloud.controller;import com.lcs.springcloud.entity.OrderTbl;
import com.lcs.springcloud.feign.StockOpenFeign;
import com.lcs.springcloud.service.OrderService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;import java.math.BigDecimal;@RestController
@RequestMapping("/order")
public class OrderController {@AutowiredOrderService orderService;@AutowiredStockOpenFeign stockOpenFeign;@RequestMapping("/add")public String add(){OrderTbl orderTbl = new OrderTbl();orderTbl.setProduct_id("10");orderTbl.setTotal_amount(new BigDecimal(3000));orderTbl.setStatu(0);orderService.insert(orderTbl);String reduct = stockOpenFeign.reduct(orderTbl.getProduct_id());return "add order "+reduct;}
}

mapper类

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.lcs.springcloud.dao.OrderDao"><!-- 主键自增长的插入 --><insert id="insert" parameterType="com.lcs.springcloud.entity.OrderTbl" useGeneratedKeys="true" keyProperty="id">insert into order_tbl(product_id,total_amount,statu) values(#{product_id},#{total_amount},#{statu});</insert>
</mapper>

stock-seata 库存项目

在这里插入图片描述

数据库脚本

 create database seata_stock;
use seata_stock;CREATE TABLE `stock_tbl` (`id` int(11) NOT NULL AUTO_INCREMENT,`product_id` varchar(200) DEFAULT NULL,`count` int(11) DEFAULT NULL,PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8INSERT INTO `seata_stock`.`stock_tbl` (`id`, `product_id`, `count`) VALUES (1, '10', 100);

pom.xml

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd"><modelVersion>4.0.0</modelVersion><parent><groupId>com.lcs.springcloud</groupId><artifactId>springcloudalibaba</artifactId><version>0.0.1-SNAPSHOT</version></parent><artifactId>stock-seata</artifactId><packaging>jar</packaging><dependencies><!-- Nacos服务注册发现--><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId></dependency><!--继承了父项目,不需要添加版本号--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><!-- jdbc --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-jdbc</artifactId><version>2.3.5.RELEASE</version></dependency><!-- mybatis --><dependency><groupId>org.mybatis.spring.boot</groupId><artifactId>mybatis-spring-boot-starter</artifactId><version>1.3.2</version><!-- 排除冲突的jar包文件--><exclusions><exclusion><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-jdbc</artifactId></exclusion></exclusions></dependency><!--Mysql驱动器--><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>8.0.18</version><scope>runtime</scope></dependency><!-- druid--><dependency><groupId>com.alibaba</groupId><artifactId>druid-spring-boot-starter</artifactId><version>1.1.9</version></dependency></dependencies><build><finalName>order-seata</finalName></build>
</project>

application.yml

server:port: 8200spring:application:name: stock-seatacloud:nacos:discovery:namespace: publicserver-addr: localhost:8848username: nacospassword: nacosdatasource:type: com.alibaba.druid.pool.DruidDataSourcedruid:db-type: mysqldriver-class-name: com.mysql.jdbc.Driver#url: jdbc:mysql://10.153.96.31:3306/iomm-collection?useUnicode=true&characterEncoding=utf-8&allowMultiQueries=true&useSSL=false&serverTimezone=Asia/Shanghai&allowPublicKeyRetrieval=true&useCursorFetch=trueurl: jdbc:mysql://112.74.51.171:3306/seata_stock?useUnicode=true&characterEncoding=utf-8&allowMultiQueries=true&useSSL=false&serverTimezone=Asia/Shanghai&allowPublicKeyRetrieval=true&useCursorFetch=trueusername: rootpassword: Zy_746498
mybatis:mapper-locations: classpath:mapper/*.xml

启动类

package com.lcs.springcloud;import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;@SpringBootApplication
@MapperScan("com.lcs.springcloud.dao")
public class StockSeataApplication {public static void main(String[] args) {SpringApplication.run(StockSeataApplication.class,args);}
}

实体类

package com.lcs.springcloud.entity;public class StockTbl {private Integer id;private String product_id;private Integer count;public Integer getId() {return id;}public void setId(Integer id) {this.id = id;}public String getProduct_id() {return product_id;}public void setProduct_id(String product_id) {this.product_id = product_id;}public Integer getCount() {return count;}public void setCount(Integer count) {this.count = count;}
}

dao类

package com.lcs.springcloud.dao;import org.apache.ibatis.annotations.Param;
import org.springframework.stereotype.Repository;@Repository
public interface StockDao {void updateStock(@Param("product_id")String product_id);
}

service类

package com.lcs.springcloud.service;import com.lcs.springcloud.dao.StockDao;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;@Service
public class StockService {@AutowiredStockDao stockDao;public String updateStock(String product_id) {try {stockDao.updateStock(product_id);return "扣减库存成功";}catch (Exception e){return "更新库存失败";}}
}

controller类

package com.lcs.springcloud.controller;import com.lcs.springcloud.service.StockService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;@RestController
@RequestMapping("/stock")
public class StockController {@AutowiredStockService stockService;@Value("${server.port}")String port;@RequestMapping("/reduct")public String reduct(@RequestParam(value = "product_id") String product_id){return stockService.updateStock(product_id);}}

mapper类

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.lcs.springcloud.dao.StockDao"><!-- 主键自增长的插入 --><update id="updateStock"  parameterType="java.lang.String" >update stock_tbl  SET count= count-1 where product_id=#{product_id}</update>
</mapper>

测试

前提: 保持已经开启nacos,不知道的可以先学习一下nacos
在这里插入图片描述

  • 订单表 默认为空
    在这里插入图片描述
  • 库存表默认为100个库存

运行http://localhost:8190/order/add
在这里插入图片描述
结果如下:
在这里插入图片描述

在这里插入图片描述

  • 订单表新增一条记录,库存表-1,说明项目搭建成功

特殊情况

已知: order和stock是两个库
把order的controller代码,改一下

package com.lcs.springcloud.controller;import com.lcs.springcloud.entity.OrderTbl;
import com.lcs.springcloud.feign.StockOpenFeign;
import com.lcs.springcloud.service.OrderService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.transaction.annotation.Transactional;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;import java.math.BigDecimal;@RestController
@RequestMapping("/order")
public class OrderController {@AutowiredOrderService orderService;@AutowiredStockOpenFeign stockOpenFeign;@RequestMapping("/add")@Transactionalpublic String add(){OrderTbl orderTbl = new OrderTbl();orderTbl.setProduct_id("10");orderTbl.setTotal_amount(new BigDecimal(3000));orderTbl.setStatu(0);//1. 插入订单orderService.insert(orderTbl);//2. 扣减库存String reduct = stockOpenFeign.reduct(orderTbl.getProduct_id());// 3. 出现问题int a= 1/0;return "add order "+reduct;}
}

在这里插入图片描述

  • 都知道0不能作为分母,必报错, 大家说一下这个接口是多少?
    订单插入进行了回滚,库存表进行扣减库存,为什么?
    这是因为@transaction事物是不支持跨库回滚的。

分布式事务

代码版本在上续上面做改动,请保证上面能先运行后, 再看该步骤

order-seata项目变动

pom.xml

 <dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-seata</artifactId><version>2.2.5.RELEASE</version></dependency><dependency><groupId>cglib</groupId><artifactId>cglib</artifactId><version>3.3.0</version></dependency>
  • 为什么加了一个cglib的包?
    在这里插入图片描述
  • 报cg相关的一个错,猜测估计是依赖冲突的问题,查了一下项目依赖,发现只有可能cglib的问题
    在这里插入图片描述

application.yml

server:port: 8190spring:application:name: order-seatacloud:nacos:discovery:namespace: publicserver-addr: localhost:8848username: nacospassword: nacosalibaba:seata:tx-service-group: default_tx_groupdatasource:type: com.alibaba.druid.pool.DruidDataSourcedruid:db-type: mysqldriver-class-name: com.mysql.jdbc.Driverurl: jdbc:mysql://127.0.0.1:3306/seata_order?useUnicode=true&characterEncoding=utf-8&allowMultiQueries=true&useSSL=false&serverTimezone=Asia/Shanghai&allowPublicKeyRetrieval=true&useCursorFetch=trueusername: rootpassword: 123456
mybatis:mapper-locations: classpath:mapper/*.xmlseata:registry:#配置seata的注册中心type: nacosnacos:### nacos服务器地址server-addr: localhost:8848username: nacospassword: nacos### nacos服务名application: seata-serverconfig:type: nacosnacos:### nacos服务器地址server-addr: localhost:8848username: nacospassword: nacosgroup: SEATA_GROUP

在这里插入图片描述

  • 为什么叫这个名字,看自己seata-server的配置
    在这里插入图片描述
    在这里插入图片描述
  • 这里标红的,就是我们需要填写的名字,在网上可以查到很多叫guangzhou的,这是因为别人重命名咯

controller

在这里插入图片描述

  • 注解改为@GlobalTransactional,表示是分布式事务

stock-seata项目变动

pom.xml

 <dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-seata</artifactId><version>2.2.5.RELEASE</version></dependency><dependency><groupId>cglib</groupId><artifactId>cglib</artifactId><version>3.3.0</version></dependency>

application.yml

server:port: 8200spring:application:name: stock-seatacloud:nacos:discovery:namespace: publicserver-addr: localhost:8848username: nacospassword: nacosalibaba:seata:tx-service-group: default_tx_groupdatasource:type: com.alibaba.druid.pool.DruidDataSourcedruid:db-type: mysqldriver-class-name: com.mysql.jdbc.Driverurl: jdbc:mysql://127.0.0.1:3306/seata_stock?useUnicode=true&characterEncoding=utf-8&allowMultiQueries=true&useSSL=false&serverTimezone=Asia/Shanghai&allowPublicKeyRetrieval=true&useCursorFetch=trueusername: rootpassword: 123456
mybatis:mapper-locations: classpath:mapper/*.xmlseata:registry:#配置seata的注册中心type: nacosnacos:### nacos服务器地址server-addr: localhost:8848username: nacospassword: nacos### nacos服务名application: seata-serverconfig:type: nacosnacos:### nacos服务器地址server-addr: localhost:8848username: nacospassword: nacosgroup: SEATA_GROUP
  • 跟order项目类似,就是client跟seata以及nacos进行通信

脚本

CREATE TABLE `undo_log` (`id` bigint(20) NOT NULL AUTO_INCREMENT,`branch_id` bigint(20) NOT NULL,`xid` varchar(100) NOT NULL,`context` varchar(128) NOT NULL,`rollback_info` longblob NOT NULL,`log_status` int(11) NOT NULL,`log_created` datetime NOT NULL,`log_modified` datetime NOT NULL,`ext` varchar(100) DEFAULT NULL,PRIMARY KEY (`id`),UNIQUE KEY `ux_undo_log` (`xid`,`branch_id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8;

在这里插入图片描述

  • 涉及到分布式事务的库,都需要新增该undo-log得表,他会记录修改前,以及修改后的sql,以便逆向回滚
  • 例如你执行了新增,逆向就是删除

效果

在这里插入图片描述

  • order表
    在这里插入图片描述
  • 库存表

在这里插入图片描述
执行http://localhost:8190/order/add,查看数据库,出现异常后

  • 之前使用@transation是,订单回滚,库存减咯
  • 选择使用@globaTransation注解,订单回滚,库存不变

分布式事务原理

nacos配置问题

在这里插入图片描述
启动后,在bin下面多了一个store开头的文件夹,why?
我不是改成db模式吗?为什么配置没有生效,查了半天,才发现nacos的配置,竟然是默认的
在这里插入图片描述

  • 搜索store.mode*改成db

启动项目后,竟然报数据库的一个错误,怎么可能,我数据库的配置,都是copy的项目里面,不可能出问题,那原因只有一个,就是nacos里面的初始化配置又有问题
在这里插入图片描述

  • 修改nacos这三个的配置,再启动项目,seata得bin下面,没有文件夹生成,说明切换成db模式成功

seata的几个表都是什么情况

在这里插入图片描述

  • seata的表

在这里插入图片描述

  • 这是seata的一个流程图
    在这里插入图片描述
  • 输入http://localhost:8190/order/add,在进入方法的时候打入断点
    在这里插入图片描述
    在这里插入图片描述
  • global_table表生成了一个xid 拼接方式是ip+端口再加一个唯一id
  • xid 全局事务id
  • application_id 应用id
  • transaction_service_group 分组
  • transaction_name 事物加在那个方法上面(以前有个版本会标注在具体类具体方法),新版本后,变动了,好奇他底层是什么映射的,知道的,可以下方交流一下
    在这里插入图片描述
  • 断点执行到这里
    在这里插入图片描述
  • branch_table 表新增了一条数据,这个是分支Xid
    在这里插入图片描述
  • 订单库的undo-log,也新增了一条数据
    在这里插入图片描述
  • lock_table表变化会存储锁表的信息
  • pk就是主键的id
#到order库调用该sql,查看blob存放的内容
select CONVERT(t.rollback_info USING utf8) from undo_log t
  • 如下图
    在这里插入图片描述
  • 因为是插入语句,所以beforeImage之前是没有数据的,afterImage存放的就是修改后的数据

断点走完后,所有的seata表数据都会回滚,如果遇到异常退出的情况,请先清空表数据

代码下载

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/801505.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

STM32学习和实践笔记(5):时钟树

STM32一共有4个时钟源。外部时钟高低速各一个&#xff0c;内部时钟高低速各一个。 外部高速时钟是&#xff1a;4-16MHZ的HSE OSC。HS表示高速high speed. E表示外部的external。开发板该处安装的8M晶振。 外部低速时钟是&#xff1a;32.768KHz的LSI OSC。LS表示高速low speed…

为说阿拉伯语的国家进行游戏本地化

阿拉伯语是由超过4亿人使用的语言&#xff0c;并且是二十多个国家的官方语言。进入这些国家的市场并非易事——虽然他们共享一种通用语言&#xff0c;但每个国家都有自己独特的文化&#xff0c;有自己的禁忌和对审查的处理方式。这就是为什么视频游戏公司长期以来都远离阿拉伯语…

Qt QML的插件(Qt Quick 2 Extension Plugin)方法

Qt Quick的插件方法 序言环境前置注意概念——Qt Quick插件的相关知识插件里的qml文件模块名的相关知识模块名本身注意事项模块名版本注意事项 以示例来说明创建插件qmltypes的生成qmltypes的可能性失效 插件的编码注意1、插件模块版本控制2、pro里的注意 调用插件插件信息输入…

华为手机 鸿蒙系统 或者安卓系统的百度网盘下载的文件保存在手机什么位置如何查看

华为手机 鸿蒙系统 或者安卓系统的百度网盘下载的文件保存在手机什么位置如何查看 连接电脑后一般在这里位置 计算机\Mate 20 Pro (UD)\内部存储\Download\BaiduNetdisk 也就是用usb&#xff08;数据线&#xff0c;不是充电线&#xff0c;要四心的 )连接手机后&#xff0c;打…

计算机网络——40各个层次的安全性

各个层次的安全性 安全电子邮件 Alice需要发送机密的报文m给Bob Alice 产生随机的对称秘钥&#xff0c; K s K_s Ks​使用 K s K_s Ks​对报文进行加密&#xff08;为了效率&#xff09;对 K s K_s Ks​使用Bob的公钥进行加密发送 K s ( m ) K_s(m) Ks​(m)和 K B ( K S ) K…

uniapp如何配置后使用uni.chooseLocation等地图位置api

在uniapp中想要使用uni.getLocation、uni.chooseLocation ……api的时候我们需要在小程序就开启配置&#xff0c;不然无法使用。 第一步&#xff1a;首先找到manifest.json 第二步&#xff1a;点击源码视图 第三步&#xff1a;在 mp-weixin 加入下面代码 "permission&…

Paper Digest | GPT-RE:基于大语言模型针对关系抽取的上下文学习

持续分享 SPG 及 SPG LLM 双驱架构应用相关进展 1、动机 在很多自然语言处理任务中&#xff0c;上下文学习的性能已经媲美甚至超过了全资源微调的方法。但是&#xff0c;其在关系抽取任务上的性能却不尽如人意。以 GPT-3 为例&#xff0c;一些基于 GPT-3 的上下文学习抽取方…

DXP学习002-PCB编辑器的环境参数及电路板参数相关设置

目录 一&#xff0c;dxp的pcb编辑器环境 1&#xff0c;创建新的PCB设计文档 2&#xff0c;PCB编辑器界面 1&#xff09;布线工具栏 2&#xff09;公用工具栏 3&#xff09;层标签栏 ​编辑 3&#xff0c;PCB设计面板 1&#xff09;打开pcb设计面板 4&#xff0c;PCB观…

【HTML】简单制作一个分形动画

目录 前言 开始 HTML部分 效果图 ​编辑​编辑​编辑​编辑总结 前言 无需多言&#xff0c;本文将详细介绍一段代码&#xff0c;具体内容如下&#xff1a; 开始 首先新建文件夹&#xff0c;创建一个文本文档&#xff0c;其中HTML的文件名改为[index.html]&a…

JavaEE初阶之单例模式详解

目录 题外话 正题 单例模式 概念 优点 缺点 饿汉式单例模式 代码及详解 懒汉式单例模式 代码及详解 小结 题外话 昨天爬山去了,回来吃了个烧烤有点累,昨天旷了一天,每周稳定发个五篇文章是没什么太大问题的 正题 单例模式 概念 是一种常见的软件设计模式,确保一个类…

nginx 配置访问地址和解决跨域问题(反向代理)

1、配置访问地址&#xff08;通过ip访问&#xff09; //配置ip访问地址 location ^~/auditApp{alias /usr/local/front-apps/cbd/auditApp;index index.html;if (!-e $request_filename) {rewrite ^/(.*) /auditApp/index.html last;break;}} 2、解决跨域问题&…

电商技术揭秘十四:大数据平台的选择与构建

相关系列文章 电商技术揭秘一&#xff1a;电商架构设计与核心技术 电商技术揭秘二&#xff1a;电商平台推荐系统的实现与优化 电商技术揭秘三&#xff1a;电商平台的支付与结算系统 电商技术揭秘四&#xff1a;电商平台的物流管理系统 电商技术揭秘五&#xff1a;电商平台…

如何使用Java和RabbitMQ实现延迟队列(方式二)?

前言 昨天写了一篇关于Java和RabbitMQ使用插件实现延迟队列功能的文章&#xff0c;今天来讲下另外一种方式&#xff0c;不需要RabbitMQ的插件。 前期准备&#xff0c;需要安装好docker、docker-compose的运行环境。 需要安装RabbitMQ的可以看下面这篇文章。 如何使用PHP和R…

AWS入门实践-在EC2上部署Wordpress网站

在AWS EC2上部署WordPress涉及到几个步骤&#xff0c;包括启动EC2实例、配置数据库、安装WordPress等。以下是详细的步骤和相应的命令脚本 第一步: 启动 EC2 实例 登录 AWS 控制台,进入 EC2 服务启动一个新的 EC2 实例,选择 Amazon Linux 2 AMI选择合适的实例类型(例如 t2.mi…

Java-接口-定义接口Filter及其实现类WordFilter

所谓&#xff1a;“纸上得来终觉浅&#xff0c;绝知此事要躬行。” 关于接口的知识&#xff0c;可以几分钟过一遍&#xff1a;Java-接口—知识&#xff08;基础&#xff09;-CSDN博客 现在就是练习time&#xff0c;先来看题&#xff1a; 定义一个接口 Filter&#xff0c;表示…

linux之shell命令

shell基础命令 浏览Linux 文件系统 Linux 系统目录结构 /bin&#xff1a; bin 是 Binaries (二进制文件) 的缩写, 这个目录存放着最经常使用的命令。 /boot&#xff1a; 这里存放的是启动 Linux 时使用的一些核心文件&#xff0c;包括一些连接文件以及镜像文件。 /dev &…

免费分享 .NET C#面试宝典

为.NET和C#开发者准备的全面指南&#xff0c;涵盖了从基础知识到高级应用的各个方面。以下是对手册内容的详细总结&#xff0c;分为多个关键点进行阐述。 1. 基础语法和数据类型 数据类型和变量&#xff1a;手册介绍了基本数据类型如int、double、bool等&#xff0c;以及如何…

微服务初始及Eureka注册中心

1&#xff0c;架构演变 单体架构&#xff1a;将所有业务功能集中在一个项目中开发&#xff0c;达成一个包部署 优点&#xff1a;架构简单&#xff0c;部署成本低 缺点&#xff1a;项目耦合度高 分布式架构&#xff1a;根据业务功能对系统进行拆分&#xff0c;每个业务作为独…

PCB学习记录-----入门基础知识

一、搭建环境 1.下载嘉立创EDA 软件下载 - 嘉立创EDA (lceda.cn) 选专业版 在线编辑&#xff1a;嘉立创EDA(专业版) - V2.1.45 (lceda.cn) 官方教程&#xff1a;立创EDA专业版-使用教程 (lceda.cn) 2.新建工程 文件-新建-项目&#xff0c;右键Board1可以重命名&#xff…

-bash: cd: /etc/hadoop: 没有那个文件或目录

解决办法&#xff1a;source /etc/profile 运行 source /etc/profile 命令会重新加载 /etc/profile 文件中的配置&#xff0c;这样做的目的是使任何更改立即生效&#xff0c;而不需要注销并重新登录用户。通常&#xff0c;/etc/profile 文件包含系统范围的全局 Shell 配置&…