nodejs连接oracle批量更新数据测试

2024-04-25 13:12

本文主要是介绍nodejs连接oracle批量更新数据测试,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

条件:oracle数据库,数据表20w。所有测试都在本机执行,保持相同的网络带宽。因为机器性能和更新速度问题,这里只测试更新1w数据。

方式1:nodejs代码程序块更新

    const sql = "declare i number:= 0;begin"+ " while i < 10000 loop"+ " update FDC_G_INFORMATION_OPINION set updatezd1 = '字段111111',updatezd2 = '字段111111',updatezd3 = '字段111111',updatezd4 ='字段111111' where id = i; i := i+1; "+ " end loop; "+ " commit;"+ " end;"await dbTarget.execute(sql);

用时:128s 

方式2:nodejs代码逐条更新

    const sqlStatements = [];for (let i = 0; i < 10000; i++) {sqlStatements.push("update table1 set updatezd1 = '字段111111',updatezd2 = '字段111111',updatezd3 = '字段111111',updatezd4 = '字段111111' where id = " + i)}// 3. 批量执行SQL语句  for (const sql of sqlStatements) {// 执行SQL语句  await dbTarget.execute(sql);}await dbTarget.commit();

用时:295s

方式3:nodejs代码批量执行

    const sql = 'UPDATE table1 SET updatezd1 = :value1, updatezd2 = :value2, updatezd3 = :value3, updatezd4 = :value4 WHERE id = :id';const bindVars = [];for (let i = 0; i < 10000; i++) {bindVars.push({ id: i, value1: 'newValue1_1', value2: 'newValue2_1', value3: 'newValue2_1', value4: 'newValue2_1' })}// 3. 执行批量更新  const options = {autoCommit: true, // 如果需要手动提交事务,可以设置为false,并在所有操作完成后调用connection.commit()  };await dbTarget.executeMany(sql, bindVars, options);

用时:156s 

这里只是简单测试,其实速度快慢比较大家想都能想出来,程序块执行速度肯定是最快的,因为我们把更新压力转移到数据库内存里去了;批量更新比逐条更新也快了很多,不过只适合固定更新字段的。

为了灵活起见,可不可以把程序需要执行的sql写到程序块呢,这样直接塞到数据库中执行岂不美哉?当然可以,目前没有发现程序段的代码量有限制,不过也要考虑数据库的性能问题,哈哈。

创作不易,有收获的老铁帮忙点个赞。

这篇关于nodejs连接oracle批量更新数据测试的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/934782

相关文章

shell脚本批量导出redis key-value方式

《shell脚本批量导出rediskey-value方式》为避免keys全量扫描导致Redis卡顿,可先通过dump.rdb备份文件在本地恢复,再使用scan命令渐进导出key-value,通过CN... 目录1 背景2 详细步骤2.1 本地docker启动Redis2.2 shell批量导出脚本3 附录总

批量导入txt数据到的redis过程

《批量导入txt数据到的redis过程》用户通过将Redis命令逐行写入txt文件,利用管道模式运行客户端,成功执行批量删除以Product*匹配的Key操作,提高了数据清理效率... 目录批量导入txt数据到Redisjs把redis命令按一条 一行写到txt中管道命令运行redis客户端成功了批量删除k

Oracle查询表结构建表语句索引等方式

《Oracle查询表结构建表语句索引等方式》使用USER_TAB_COLUMNS查询表结构可避免系统隐藏字段(如LISTUSER的CLOB与VARCHAR2同名字段),这些字段可能为dbms_lob.... 目录oracle查询表结构建表语句索引1.用“USER_TAB_COLUMNS”查询表结构2.用“a

Redis客户端连接机制的实现方案

《Redis客户端连接机制的实现方案》本文主要介绍了Redis客户端连接机制的实现方案,包括事件驱动模型、非阻塞I/O处理、连接池应用及配置优化,具有一定的参考价值,感兴趣的可以了解一下... 目录1. Redis连接模型概述2. 连接建立过程详解2.1 连php接初始化流程2.2 关键配置参数3. 最大连

Oracle数据库定时备份脚本方式(Linux)

《Oracle数据库定时备份脚本方式(Linux)》文章介绍Oracle数据库自动备份方案,包含主机备份传输与备机解压导入流程,强调需提前全量删除原库数据避免报错,并需配置无密传输、定时任务及验证脚本... 目录说明主机脚本备机上自动导库脚本整个自动备份oracle数据库的过程(建议全程用root用户)总结

SQL Server跟踪自动统计信息更新实战指南

《SQLServer跟踪自动统计信息更新实战指南》本文详解SQLServer自动统计信息更新的跟踪方法,推荐使用扩展事件实时捕获更新操作及详细信息,同时结合系统视图快速检查统计信息状态,重点强调修... 目录SQL Server 如何跟踪自动统计信息更新:深入解析与实战指南 核心跟踪方法1️⃣ 利用系统目录

Python实现批量提取BLF文件时间戳

《Python实现批量提取BLF文件时间戳》BLF(BinaryLoggingFormat)作为Vector公司推出的CAN总线数据记录格式,被广泛用于存储车辆通信数据,本文将使用Python轻松提取... 目录一、为什么需要批量处理 BLF 文件二、核心代码解析:从文件遍历到数据导出1. 环境准备与依赖库

linux批量替换文件内容的实现方式

《linux批量替换文件内容的实现方式》本文总结了Linux中批量替换文件内容的几种方法,包括使用sed替换文件夹内所有文件、单个文件内容及逐行字符串,强调使用反引号和绝对路径,并分享个人经验供参考... 目录一、linux批量替换文件内容 二、替换文件内所有匹配的字符串 三、替换每一行中全部str1为st

基于Python开发一个图像水印批量添加工具

《基于Python开发一个图像水印批量添加工具》在当今数字化内容爆炸式增长的时代,图像版权保护已成为创作者和企业的核心需求,本方案将详细介绍一个基于PythonPIL库的工业级图像水印解决方案,有需要... 目录一、系统架构设计1.1 整体处理流程1.2 类结构设计(扩展版本)二、核心算法深入解析2.1 自

Python自动化批量重命名与整理文件系统

《Python自动化批量重命名与整理文件系统》这篇文章主要为大家详细介绍了如何使用Python实现一个强大的文件批量重命名与整理工具,帮助开发者自动化这一繁琐过程,有需要的小伙伴可以了解下... 目录简介环境准备项目功能概述代码详细解析1. 导入必要的库2. 配置参数设置3. 创建日志系统4. 安全文件名处