多线程插入数据保证所有线程的事务一致性

public class OperationTestService implements OperationTest {
    @Autowired
    private OperationPriceMapper operationPriceMapper;
    @Autowired
    private DataSourceTransactionManager dataSourceTransactionManager;
    @Autowired
    private TransactionDefinition transactionDefinition;
    /**
     * 获取 CPU 核心数
     */
    int corePoolSize = Runtime.getRuntime().availableProcessors();
    private final ThreadPoolExecutor executor = new ThreadPoolExecutor(corePoolSize, 100, 30, TimeUnit.SECONDS, new ArrayBlockingQueue<>(500), new ThreadPoolExecutor.CallerRunsPolicy());

 
    public void excelImp() {
        //读取excel中的数据并添加到list中
        List<OperationPrice> list1 = new ArrayList<>();
        List<OperationPrice> list2 = new ArrayList<>();
        List<OperationPrice> list3 = new ArrayList<>();
        EasyExcel.read("D:\\DELL\\Documents\\WXWork\\1688856128511192\\Cache\\File\\2024-03\\demo1.xlsx",
                OperationPrice.class, new PageReadListener<OperationPrice>(list1::addAll)).sheet().doRead();
        EasyExcel.read("D:\\DELL\\Documents\\WXWork\\1688856128511192\\Cache\\File\\2024-03\\demo2.xlsx",
                OperationPrice.class, new PageReadListener<OperationPrice>(list2::addAll)).sheet().doRead();
        EasyExcel.read("D:\\DELL\\Documents\\WXWork\\1688856128511192\\Cache\\File\\2024-03\\demo3.xlsx",
                OperationPrice.class, new PageReadListener<OperationPrice>(list3::addAll)).sheet().doRead();

        AtomicBoolean commit = new AtomicBoolean(true);
        CyclicBarrier barrier = new CyclicBarrier(3);
        executor.execute(() -> {
            TransactionStatus status = dataSourceTransactionManager.getTransaction(transactionDefinition);
            try {
                //插入数据
                operationPriceMapper.insertBatch(list1);
                //异常
                int i = 1 / 0;
            } catch (Exception e) {
                //如果异常就把事务提交设置false
                commit.set(false);
            } finally {
                try {
                    //线程进入屏障点,后面的程序将不会执行,直到所有线程都进入这个屏障点一起执行
                    barrier.await();
                } catch (Exception e) {
                }
                //判断是否提交事务
                if (commit.get()) {
                    dataSourceTransactionManager.commit(status);
                } else {
                    dataSourceTransactionManager.rollback(status);
                }
            }

        });
        executor.execute(() -> {
            TransactionStatus status = dataSourceTransactionManager.getTransaction(transactionDefinition);
            try {
                operationPriceMapper.insertBatch(list2);
            } catch (Exception e) {
                commit.set(false);
            } finally {
                try {
                    barrier.await();
                } catch (Exception e) {
                }
                if (commit.get()) {
                    dataSourceTransactionManager.commit(status);
                } else {
                    dataSourceTransactionManager.rollback(status);
                }
            }

        });
        executor.execute(() -> {
            TransactionStatus status = dataSourceTransactionManager.getTransaction(transactionDefinition);
            try {
                operationPriceMapper.insertBatch(list3);
            } catch (Exception e) {
                commit.set(false);
            } finally {
                try {
                    barrier.await();
                } catch (Exception e) {
                }
                if (commit.get()) {
                    dataSourceTransactionManager.commit(status);
                } else {
                    dataSourceTransactionManager.rollback(status);
                }
            }
        });
    }

  • 11
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
逻辑结构:描述数据元素之间的逻辑关系,如线性结构(如数组、链表)、树形结构(如二叉树、堆、B树)、图结构(有向图、无向图等)以及集合和队列等抽象数据类型。 存储结构(物理结构):描述数据在计算机中如何具体存储。例如,数组的连续存储,链表的动态分配节点,树和图的邻接矩阵或邻接表表示等。 基本操作:针对每种数据结构,定义了一系列基本的操作,包括但不限于插入、删除、查找、更新、遍历等,并分析这些操作的时间复杂度和空间复杂度。 算法: 算法设计:研究如何将解决问题的步骤形式化为一系列指令,使得计算机可以执行以求解问题。 算法特性:包括输入、输出、有穷性、确定性和可行性。即一个有效的算法必须能在有限步骤内结束,并且对于给定的输入产生唯一的确定输出。 算法分类:排序算法(如冒泡排序、快速排序、归并排序),查找算法(如顺序查找、二分查找、哈希查找),图论算法(如Dijkstra最短路径算法、Floyd-Warshall算法、Prim最小生成树算法),动态规划,贪心算法,回溯法,分支限界法等。 算法分析:通过数学方法分析算法的时间复杂度(运行时间随数据规模增长的速度)和空间复杂度(所需内存大小)来评估其效率。 学习算法与数据结构不仅有助于理解程序的内部工作原理,更能帮助开发人员编写出高效、稳定和易于维护的软件系统。
关于java程序员发展需要学习的路线整理集合 技术 应用技术 计算机基础知识 cpu mem disk net 线程,进程 第三方库 poi Jsoup zxing Gson 数据结构 树 栈 链表 队列 图 操作系统 linux 代码控制 自动化代码检查 sonar 代码规范 阿里巴巴Java开发规范手册 UMPAY——编码规范 日志规范 异常规范 网络 协议 TCP/IP HTTP hession file HTTPS 负载均衡 容器 JBOSS tomcat resin jetty 容灾 日志框架 开源框架 slf4j 框架实现 log4j logback commong logging jdk logger 测试框架 测试框架 junit easymock testng mockito bug管理 禅道 jira 开发工具 编程工具 eclipse myeclipse idea vi VS webstorm sublime text 版本控制 svn git 项目管理 maven Nexus Jenkins 工作软件 反编译软件 office系列 下载器 adobe系列 记录软件 思维导图 office--Note 邮件管理 性能优化 分层优化 系统级别 中间件级别 JVM级别 代码级别 分段优化 前端 web应用 服务应用 资源池 数据库数据与nosql zookeeper hadoop hbase mongodb strom spark java语言 语言语法基础 异常 泛型 内部类 反射 序列化 nIo 匿名类 包装类 优先级 引用 语言工具类库 容器类 集合 链表 map 工具类 系统类 日期类 数字类 字符串+正则 流 字符流 字节流 语言特性 继承 封装 多态 JVM 多线程与并发 GC机制 GC收集器类型 串行 CMS 并行 G1 算法 复制 标记清理 标记整理 分区 新生代 eden survivor 老年代(old区) 永久代(perm区) 版本变化 1.5 1.6 1.7 1.8 1.9 IO/NIO IO类型 同步阻塞 同步非阻塞 基于信号 多路复用 异步IO 类加载机制 双亲委派 OSGI 算法 搜索 二分 排序 选择 冒泡 插入 快速 归并 堆 桶 基数 常用算法 贪婪 回溯 剪枝 动态规划 数据挖掘算法 KMP算法 GZZ算法 HASH分桶 关联规则算法 APRORIVE算法 分布式 负载均衡 水平伸缩 集群 分片 Key-hash 异步 一致性hash 消峰 分库分表 锁 悲观锁 乐观锁 行级锁 分布式锁 分区排队 一致性 一致性算法 paxos zab nwr raft gossip 柔性事务(TCC) 一致性原理 CAP BASE 中间件 数据库 mysql 存储引擎 索引 锁 oracle db2 缓存 redis 数据结构 持久 复制 cas 单线程 memcache eacache Tair 消息队列 jms Queue Topic kafka 持久 复制 Stream Partition rocketMQ RabbitMQ ActiveMQ 常用开源框架 Spring Spring MVC Spring WebFlow spring tx aop ioc Struts ibatis Mybatis CAS Dubbo 工作能力 软实力 应急能力 创新能力 管理能力 分享能力 学习能力 沟通能力 解决问题能力 经历 技术攻关案例 程序开发案例 程序设计案例 设计 设计原则 单一职责原则 开闭原则 里氏替换原则 依赖倒转原则 接口隔离原则 迪米特原则 设计模式 结构模式 适配器模式 桥接模式 组合模式 装饰模式 外观模式 享元模式 代理模式 创建模式 抽象工厂模式 工厂方法模式 建造这模式 原型模式 单例模式 行为模式 责任链模式 命令模式 解释器模式 迭代器模式 中介者模式 备忘录模式 观察者模式 状态模式 策略模式 模板方法模式 访问者模式 设计案例 UML 架构 系统架构能力 基本理论 扩展性设计 可用性设计 可靠性设计 一致性设计 负载均衡设计 过载保护设计 协议设计 二进制协议 文本协议 接入层架构设计 DNS轮询 动静态分离 静态化 反向代理 LVS F5 CDN 逻辑层架构设计 连接池 串行化技术 影子Master架构 批量写入 配置中心 去中心化 通讯机制 同步 RPC RMI 异步 MQ Cron 数据层架构设计 缓存优化 DAO&ORM; 双主架构 主从同步 读写分离 性能优化架构能力 代码级别 关联代码优化 cache对其 分支预测 copy on write 内联优化 系统优化 cache 延迟计算 数据预读 异步 轮询与通知 内存池 模块化 工程架构能力 开发语言 运维与监控 监控 系统监控 日志监控 流量监控 接口监控 数据库监控 业务监控 性能监控 告警 日志 设计模式 数据结构与算法 各种工具

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值