MySQL批量修改记录

我们知道MySQL支持批量添加记录,用法也比较简单,不过需要编码需要注意一下,因为很容易搞错

var jargs = require('./argspw.json');
const mysql = require("mysql"); const mysqlpool= mysql.createPool({host:jargs.mysqlip,user:jargs.mysqluser,password:mycrypt.decrypt(jargs.mysqlpw),//配置文件里口令密文解密port:jargs.mysqlport,database:jargs.mysqldatabase});
const addrcs='insert into table1(id,name,age,school) values ?'
var rclist=[["id1","name1","age1","sc1"],["id2","name2","age2","sc2"],["id3","name3","age3","sc3"]]//注意每个记录是一个list,这些记录又是一个大list的成员
mysqlpool.getConnection((errmpgc, mysqlconn)=> { if (errmpgc) { console.log("建立连接失败"); } else {mysqlconn.query(addrcs,[rclist],(erriw1,results1)=> { //注意在rclist外又包裹了一对方括号if (erriw1) { console.log("SQL执行失败"); console.log(erriw1.message); }else { console.log("SQL执行成功"); }mysqlconn.release();}});

update语句是不支持批量提交的,不过可以用replace into或者insert into on duplicate key update曲线救国。需要注意的是要在table中定义主键,replace into是对重复记录先删后填加,后者是更改,如果values不全的话,前者会丢失这些信息,后者则保留这些信息。所以推荐采用后一种方法。

const updatercs='insert into table1(id,name,school) values ? on duplicate key update school=values(school),name=values(name)'
var rclist=[["id1","name11","pku"],["id2","name22","pku"],["id3","name33","pku"]]
mysqlpool.getConnection((errmpgc, mysqlconn)=> { if (errmpgc) { console.log("建立连接失败"); } else {mysqlconn.query(updatercs,[rclist],(erriw1,results1)=> { if (erriw1) { console.log("SQL执行失败"); console.log(erriw1.message); }else { console.log("SQL执行成功"); }mysqlconn.release();}});

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

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

相关文章

一款挺不错网站维护页面HTML源码

一款挺不错网站维护页面源码,单HTML不需要数据库,上传到你的虚拟机就可以用做维护页面还不错,用处多。。 源码下载 一款挺不错网站维护页面源码

Ajax使用异步对象发送请求简介

​ 文章目录 一、什么是Ajax二、全局刷新和局部刷新二、Ajax中使用XMLHttpRequest对象(Ajax核心步骤)1、创建异步对象2、给异步对象绑定事件3、异步对象的属性 readyState 表示异步对象请求的状态变化4、初始异步请求对象5、使用异步对象发送请求6、jso…

Android DB锁问题

并发访问事务 在Android中使用SQLite数据库时,如果多个线程尝试同时对同一个数据库开启事务,可能会遇到几个问题: 锁定异常 (android.database.sqlite.SQLiteDatabaseLockedException): 如果一个线程已经在数据库上持有一个写事务&#xff0…

LangChain LangServe 学习笔记

LangChain LangServe 学习笔记 0. 引言1. LangServe 概述2. 特性3. 限制4. 安装5. 示例应用程序6. OpenAPI文档7. Python SDK 客户端8. Playground9. 聊天可运行页面 0. 引言 使用 LangServe 可以立即将您的LLM应用程序变成 API 服务器。 LangServe 使用 FastAPI 构建&#x…

three.js(1):three.js简介

1 什么是three.js three.js,一个WebGL引擎,基于JavaScript,可直接运行GPU驱动游戏与图形驱动应用于浏览器。其库提供的特性与API以绘制3D场景于浏览器。 2 下载地址 three.js下载地址:https://github.com/mrdoob/three.js 3 目录介绍 下载…

【题目】【信息安全管理与评估】2022年国赛高职组“信息安全管理与评估”赛项样题5

【题目】【信息安全管理与评估】2022年国赛高职组“信息安全管理与评估”赛项样题5 第一阶段竞赛项目试题 本文件为信息安全管理与评估项目竞赛-第一阶段试题,第一阶段内容包括:网络平台搭建与设备安全防护。 本次比赛时间为180分钟。 介绍 竞赛阶段…

浅谈函数 fscanf/sscanf 和 fprintf/sprintf

目录 一,fprintf 的介绍和使用1. 函数介绍2. 函数使用 二,fscanf 的介绍和使用1. 函数介绍2. 函数使用 三,sprintf 的介绍和使用1. 函数介绍2. 函数使用 四,sscanf 的介绍和使用1,函数介绍2,函数使用 五&am…

SSL Pinning之双向认证

双向认证处理流程 概述获取证书逆向app 获取证书的KeyStore的 key通过jadx 反编译 app 获取证书:frida hook 证书转换命令行转换portecle 工具使用 charles 配置 p12 格式证书 概述 本篇只介绍怎么解决ssl pinning, 不讲ssl/tls 原理。 为了解决ssl pinn…

BCrypt实现信息加密

1.BCrypt的概述 bcrypt 是一种密码哈希函数,通常用于加密密码。它采用了 Blowfish 加密算法的变种,并结合了盐(salt)和密钥延时(key stretching)等技术,以增加密码破解的难度。 2.BCrypt的使用…

RT-Thread 多级目录 scons 构建

前言 RT-Thread 默认使用 scons 进行工程的构建,虽然 RT-Thread BSP 中的 hello world 例程比较简单,实际项目开发,可能源码的工程会由多级目录,如何让多级的目录参与构建? scons 构建时,除了依赖工程的根…

基于R语言实现的beta二项回归模型【理解与实现】

本实验,创建一组使用二项分布模拟的数据(不带额外的随机性),和另一组使用Beta二项分布模拟的数据(引入了随机成功概率 p,从而增加了数据的离散性。 现在假设我们站在上帝视角,有两组不知道分布…

【C语言】结构体structure

【C语言】结构体structure: C语言可以自定义数据类型。结构体是其中一个自定义的数据类型。结构体类型是复杂的数据类型,将多个不同数据按一定功能进行整体封装,用一个名称来给结构体命名。可用typedef为结构体提供别名。关键字struct。结构…

Android中协程的理解

Android中的协程是一种轻量级的并发编程结构,它允许在子线程中挂起和恢复运行。协程的主要目标是提高多线程编程的效率和可读性,特别是在需要频繁切换任务或操作的数据驱动的场景中。 理解协程需要理解其核心概念:任务、线程和状态。 任务&…

Qt 中默认代码

目录 主函数 widget的声明 widget的定义 form file .pro 文件 主函数 #include "widget.h" ​ #include <QApplication> ​ int main(int argc, char *argv[]) {QApplication a(argc, argv);Widget w;w.show();return a.exec(); } 上面就是 Qt 刚创建的一…

机器学习-随机森林温度预测模型优化

文章目录 前言旧模型训练新模型训练参数查看组合参数训练学习模型评估 前言 在机器学习-随机森林算法预测温度一文中&#xff0c;通过增大模型训练数据集和训练特征的方式去优化模型的性能&#xff0c;本文将记录第三方种优化方式&#xff0c;通过调整随机森林创建模型参数的方…

【高阶数据结构】哈希表 {哈希函数和哈希冲突;哈希冲突的解决方案:闭散列,开散列;红黑树结构 VS 哈希结构}

一、哈希表的概念 顺序结构以及平衡树 顺序结构以及平衡树中&#xff0c;元素关键码与其存储位置之间没有对应的关系。因此在查找一个元素时&#xff0c;必须要经过关键码的多次比较。顺序查找时间复杂度为O(N)&#xff1b;平衡树中为树的高度&#xff0c;即O(log_2 N)&#xf…

区间比较指令

1&#xff0c;比较值和和区间值比较 2&#xff0c;指令 ZCP K2 K5 C0 Y000 3&#xff0c;当比较值小于 区间返回 软元件灯亮 当比较直在区间内软元件1 接通 > 第一个 < 第二个 大于第二个值 软元件2接通 如果区间中第二个值大于第一个值那个只比较第一个值 直接比较 参数…

【HTML】制作一个简单的实时字体时钟

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

CSS3进阶技巧:Flexbox布局实战与高级应用

Flexbox布局是CSS3中一种强大的布局技术&#xff0c;它可以帮助我们更灵活地布局网页元素&#xff0c;解决传统布局方式中的一些问题。在本文中&#xff0c;我将介绍一些Flexbox布局的进阶技巧和高级应用。 Flexbox的基本概念 Flexbox布局是基于弹性盒子模型的&#xff0c;它主…

设计模式:生活中的命令模式

将命令模式类比到日常生活中,可以想象一个餐厅的运作过程。在这个类比中,顾客点菜的过程就像是发出一个命令,而厨师则是执行命令的接收者。 角色类比 顾客(Client):下达命令。他们决定要什么菜,并通知服务员。服务员(Invoker):接收命令,并传递给厨师。服务员不需要…