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

相关文章

MySQL新增字段后Java实体未更新的潜在问题与解决方案

《MySQL新增字段后Java实体未更新的潜在问题与解决方案》在Java+MySQL的开发中,我们通常使用ORM框架来映射数据库表与Java对象,但有时候,数据库表结构变更(如新增字段)后,开发人员可... 目录引言1. 问题背景:数据库与 Java 实体不同步1.1 常见场景1.2 示例代码2. 不同操作

Spring Boot 整合 MyBatis 连接数据库及常见问题

《SpringBoot整合MyBatis连接数据库及常见问题》MyBatis是一个优秀的持久层框架,支持定制化SQL、存储过程以及高级映射,下面详细介绍如何在SpringBoot项目中整合My... 目录一、基本配置1. 添加依赖2. 配置数据库连接二、项目结构三、核心组件实现(示例)1. 实体类2. Ma

电脑win32spl.dll文件丢失咋办? win32spl.dll丢失无法连接打印机修复技巧

《电脑win32spl.dll文件丢失咋办?win32spl.dll丢失无法连接打印机修复技巧》电脑突然提示win32spl.dll文件丢失,打印机死活连不上,今天就来给大家详细讲解一下这个问题的解... 不知道大家在使用电脑的时候是否遇到过关于win32spl.dll文件丢失的问题,win32spl.dl

Windows Server服务器上配置FileZilla后,FTP连接不上?

《WindowsServer服务器上配置FileZilla后,FTP连接不上?》WindowsServer服务器上配置FileZilla后,FTP连接错误和操作超时的问题,应该如何解决?首先,通过... 目录在Windohttp://www.chinasem.cnws防火墙开启的情况下,遇到的错误如下:无法与

Oracle存储过程里操作BLOB的字节数据的办法

《Oracle存储过程里操作BLOB的字节数据的办法》该篇文章介绍了如何在Oracle存储过程中操作BLOB的字节数据,作者研究了如何获取BLOB的字节长度、如何使用DBMS_LOB包进行BLOB操作... 目录一、缘由二、办法2.1 基本操作2.2 DBMS_LOB包2.3 字节级操作与RAW数据类型2.

一文详解SQL Server如何跟踪自动统计信息更新

《一文详解SQLServer如何跟踪自动统计信息更新》SQLServer数据库中,我们都清楚统计信息对于优化器来说非常重要,所以本文就来和大家简单聊一聊SQLServer如何跟踪自动统计信息更新吧... SQL Server数据库中,我们都清楚统计信息对于优化器来说非常重要。一般情况下,我们会开启"自动更新

查看Oracle数据库中UNDO表空间的使用情况(最新推荐)

《查看Oracle数据库中UNDO表空间的使用情况(最新推荐)》Oracle数据库中查看UNDO表空间使用情况的4种方法:DBA_TABLESPACES和DBA_DATA_FILES提供基本信息,V$... 目录1. 通过 DBjavascriptA_TABLESPACES 和 DBA_DATA_FILES

基于Python开发批量提取Excel图片的小工具

《基于Python开发批量提取Excel图片的小工具》这篇文章主要为大家详细介绍了如何使用Python中的openpyxl库开发一个小工具,可以实现批量提取Excel图片,有需要的小伙伴可以参考一下... 目前有一个需求,就是批量读取当前目录下所有文件夹里的Excel文件,去获取出Excel文件中的图片,并

IDEA连接达梦数据库的详细配置指南

《IDEA连接达梦数据库的详细配置指南》达梦数据库(DMDatabase)作为国产关系型数据库的代表,广泛应用于企业级系统开发,本文将详细介绍如何在IntelliJIDEA中配置并连接达梦数据库,助力... 目录准备工作1. 下载达梦JDBC驱动配置步骤1. 将驱动添加到IDEA2. 创建数据库连接连接参数

Jmeter如何向数据库批量插入数据

《Jmeter如何向数据库批量插入数据》:本文主要介绍Jmeter如何向数据库批量插入数据方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Jmeter向数据库批量插入数据Jmeter向mysql数据库中插入数据的入门操作接下来做一下各个元件的配置总结Jmete