node-mysql的批量插入

此前我批量插入都是用类似这样的命令:

sql 复制代码
sqlcmd='insert into table(field1,field2,...) values ?'
indata=[["f1v1","f2v1"],["f1v2","f2v2"],...]
mysqlconn.query(sqlcmd,[indata],(err,res)=>{
	...
	})

但是感觉不太舒服,因为要在两处写出字段顺序,命令串里是字段名,数组里是字段值,顺序不能错,否则执行结果不符合预期。

我们知道单条记录插入是可以用以下方式执行

sql 复制代码
sqlcmd='insert into table set ?'
indata={filed1:"f1v1",filed2:"f2v1"}
mysqlconn.query(sqlcmd,indata,(err,res)=>{
	...

不必关注字段顺序的key-value对顺序,数据是以json方式定义,不容易出错。

那么批量插入难道不能用json数组这种方式书写么?

sql 复制代码
sqlcmd='insert into table values ?'
indata=[{filed1:"f1v1",filed2:"f2v1"},{filed1:"f1v2",filed2:"f2v2"},...]
mysqlconn.query(sqlcmd,indata,(err,res)=>{
	...
	})

网上搜到极客笔记里一篇《MySQL如何利用Node.js进行批量插入操作》,跟这个书写方式一样,文章里的意思是没有问题,而且作者还验证了下批量的速度。

但是在我的windows环境下却只能插入第一条数据,后面的都没有生效。

应该是在命令生成的时候,只解析了第一条,以下是node-mysql格式转换结果

sql 复制代码
//mysqlstr.js
const mysql = require("mysql"); 
const sqlcmd="insert into table set ?"
const indata=[
{field1:"f1v1",field2:"f2v1"},
{field1:"f1v2",field2:"f2v2"},
]
let mysqlstr=mysql.format(sqlcmd,indata);
console.log(mysqlstr)

indata数组后面的内容被丢弃了。。。

不知道linux环境下结果是否会不一样,可惜了。

相关推荐
老徐电商数据笔记13 分钟前
BI工具与数据分析平台:数据价值呈现的最后一公里
数据库·数据挖掘·数据分析·bi·bi选型思考
码农水水1 小时前
米哈游Java面试被问:机器学习模型的在线服务和A/B测试
java·开发语言·数据库·spring boot·后端·机器学习·word
酉鬼女又兒2 小时前
SQL24 统计每个用户的平均刷题数
数据库·sql·mysql
雷工笔记2 小时前
数据库|SQLServer2025安装教程
数据库·sqlserver
一只自律的鸡3 小时前
【MySQL】第六章 子查询
数据库·mysql
Knight_AL3 小时前
Spring Boot 事件机制详解:原理 + Demo
java·数据库·spring boot
野人李小白3 小时前
DBeaver 界面友好,支持多种数据库,具备强大的 SQL 编辑、可视化查询、数据迁移及插件扩展功能,是开发者首选的数据库管理工具。
数据库·sql
山峰哥3 小时前
SQL索引优化实战:3000字深度解析查询提速密码
大数据·数据库·sql·编辑器·深度优先
观音山保我别报错4 小时前
消息队列项目基础知识总结
linux·服务器·数据库
jghhh014 小时前
MATLAB分形维数计算:1D/2D/3D图形的盒维数实现
数据库·matlab