位置: 编程技术 - 正文

使用JDBC在MySQL数据库中如何快速批量插入数据(mysql jdbc)

编辑:rootadmin

推荐整理分享使用JDBC在MySQL数据库中如何快速批量插入数据(mysql jdbc),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mysql-jdbc,jdbc添加数据到mysql,jdbc操作mysql,jdbc添加数据到mysql,使用jdbc操作数据库步骤,jdbc mysql8,mysql-jdbc,jdbc操作mysql数据库,内容如对您有帮助,希望把文章链接给更多的朋友!

使用JDBC连接MySQL数据库进行数据插入的时候,特别是大批量数据连续插入(W+),如何提高效率呢?

在JDBC编程接口中Statement 有两个方法特别值得注意:

Adds a set of parameters to this PreparedStatement object's batch of commands.

Submits a batch of commands to the database for execution and if all commands execute successfully, returns an array of update counts. The int elements of the array that is returned are ordered to correspond to the commands in the batch, which are ordered according to the order in which they were added to the batch.

通过使用addBatch()和executeBatch()这一对方法可以实现批量处理数据。

不过值得注意的是,首先需要在数据库链接中设置手动提交,connection.setAutoCommit(false),然后在执行Statement之后执行connection.commit()。

执行完成以后:

使用JDBC在MySQL数据库中如何快速批量插入数据(mysql jdbc)

All down : Convert finished. All spend time/s :

一共W+,执行时间一共花费 秒.

这个效率仍然不高,似乎没有达到想要的效果,需要进一步改进。

在MySQL JDBC连接字符串中还可以加入参数,

rewriteBatchedStatements=true,mysql默认关闭了batch处理,通过此参数进行打开,这个参数可以重写向数据库提交的SQL语句。

useServerPrepStmts=false,如果不开启(useServerPrepStmts=false),使用com.mysql.jdbc.PreparedStatement进行本地SQL拼装,最后送到db上就是已经替换了&#;后的最终SQL.

在此稍加改进,连接字符串中加入下面语句(代码构造方法中去掉注释):connectStr += "&#;useServerPrepStmts=false&rewriteBatchedStatements=true";

再次执行如下:

All down : Convert finished. All spend time/s :

同样的数据量,这次执行只花费了秒 ,处理效率大大提高.

标签: mysql jdbc

本文链接地址:https://www.jiuchutong.com/biancheng/349236.html 转载请保留说明!

上一篇:Mysql Explain 详细介绍

下一篇:CentOS中mysql cluster安装部署教程

  • 增值税纳税申报表在哪里查询
  • 红冲以前年度的费用怎么做账
  • 工矿区城镇土地使用税
  • 职工的取暖补贴上税吗
  • 股份支付费用的会计处理怎么做?
  • 怎么查公司账户是哪个银行的
  • 当月工资额什么意思
  • 代理进口产品需要什么手续
  • 怎么查找地方教育附加税的计税依据?
  • 印花税加工承揽税率
  • 银行处置以物抵债违法吗
  • 预缴水利基金如何申报?
  • 开票资料地址填营业执照
  • 培训费发票如何入账
  • 保险公司退还保费
  • 对公账户发工资的利弊
  • 行政单位以前年度会计错账调整
  • 基本社会保障性缴款包括什么
  • u盘如何进行杀毒
  • linux |bc
  • win7网络无连接
  • 申请出具商标注意事项
  • 帮老板支付的代款怎么做
  • 个人与公司交易超过20万
  • 物权请求权如何行使
  • 法人向公司借款要交什么税
  • 增值税进项发票不够抵扣怎么办
  • win11如何将开始菜单里的软件移到桌面
  • newacs.exe是什么进程
  • php保留两位小数的函数
  • php循环语句
  • cuda completed with errors
  • 固定资产折旧怎么做账务处理
  • 美国大峡谷在哪儿
  • 有限责任公司股东对公司债务承担
  • python抓取淘宝店铺商品
  • vue安装使用
  • python字符串中变量替换
  • 增值税价税合计怎么填
  • 税控盘增值税发票怎么开
  • java的范式
  • vue动态修改scss变量
  • 企业年金是否要交个税
  • 打开access自动弹出窗体
  • 小微企业免征的增值税怎么做账
  • 息税前利润变动率怎么算
  • 哪些合同必须签订书面合同
  • 来料加工账务处理流程
  • 协会申报材料
  • 私人出租房子发圈文案
  • 退款产生的手续费怎么算
  • 工伤费退回会计分录
  • 什么是雇主责任险保单
  • 外贸公司收取国家税费吗
  • 次年发上年年终奖
  • 没有期初数据会怎么样
  • 商品流通企业如何控成本
  • 融资租入固定资产的入账价值
  • linux统计重复次数
  • win8安装出现了一些问题
  • VMware10安装Windows server2012
  • Mac Chrome打开HTTPS证书错误问题解决方法
  • 阿里云安装
  • u盘里装pe系统
  • mysql如何建立数据完整性约束
  • win8开机直接进入传统桌面
  • unity3d摄像头
  • ie内存怎么清理
  • win2000停止服务
  • unity怎么加人
  • nodejs使用视频教程
  • unity怎么学
  • JavaScript中的变量名不区分大小写
  • Android使用opencv处理图片灰度
  • 刮刮奖软件下载
  • js合并字符串
  • 护肤品关税税率
  • 企业党支部怎么称呼
  • 地税官网怎么登录
  • 开错发票怎么投诉?
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设