spring批量写入mysql数据库_MyBatis-spring和spring JDBC批量插入Mysql的效率比较

工具框架用spring-batch,数据库是mysql(未做特殊优化)。

比较数据框架mybatis和spring jdbc的插入效率。

Mybatis三种实现:

1、mybatis的官方写法

Java代码

081b1cfad599d6fed53deddf1068fe74.png

publicvoidbatchInsert1(List poilist)throwsException {

SqlSession sqlSession = sqlSessionFactory.getObject().openSession(ExecutorType.BATCH);

PoiMapper pmapper = sqlSession.getMapper(PoiMapper.class);

try{

for(Poi poi : poilist) {

pmapper.insertPoi(poi);

}

sqlSession.commit();

} finally{

sqlSession.close();

}

}

其中Poi是一个bean。

PoiMapper定义:

Java代码

081b1cfad599d6fed53deddf1068fe74.png

publicinterfacePoiMapper {

("insert into tb_poi (tag, poi, poiid, meshid, owner, featcode, sortcode, namec, namee, namep, names) values (#{tag}, GeomFromText(#{point}), #{poiid}, #{meshid}, #{owner}, #{featcode}, #{sortcode}, #{namec}, #{namee}, #{namep}, #{names}) ")

publicvoidinsertPoi(Poi poi);

}

2、利用mysql特性,拼写insert sql。

Java代码

081b1cfad599d6fed53deddf1068fe74.png

publicvoidbatchInsert2(List poilist)throwsException {

SqlSession sqlSession = sqlSessionFactory.getObject().openSession(ExecutorType.BATCH);

try{

sqlSession.insert("com.emg.trans.mapper.batchMapper.batchInsert", poilist);

sqlSession.commit();

} finally{

sqlSession.close();

}

}

“com.emg.trans.mapper.batchMapper.batchInsert”在mybatis的xml中定义的sql,定义如下:

Xml代码

081b1cfad599d6fed53deddf1068fe74.png

insert into tb_poi (tag, poi, poiid, meshid, owner, featcode, sortcode, namec, namee, namep, names) values

(#{poi.tag}, GeomFromText(#{poi.point}), #{poi.poiid}, #{poi.meshid}, #{poi.owner}, #{poi.featcode}, #{poi.sortcode}, #{poi.namec}, #{poi.namee}, #{poi.namep}, #{poi.names})

3、利用spring的事务,直接执行插入操作。

Java代码

081b1cfad599d6fed53deddf1068fe74.png

@Transactional("dbTransaction")

publicvoidbatchInsert3(List poilist)throwsException {

for(Poi poi : poilist) {

apmapper.insertPoi(poi);

}

}

apmapper是PoiMapper的实例,用@Autowired配置。

Spring-JDBC的三种实现:

A、用spring事务执行插入操作

Java代码

081b1cfad599d6fed53deddf1068fe74.png

@Transactional("dbTransaction")

publicvoidbatchInsertJDBC1(List poilist)throwsDataAccessException {

String sql = "insert into tb_poi (tag, poi, poiid, meshid, owner, featcode, sortcode, namec, namee, namep, names) values (?, GeomFromText(?), ?, ?, ?, ?, ?, ?, ?, ?, ?)";

for(Poi poi : poilist) {

Object[] args = {poi.getTag(), poi.getPoint(), poi.getPoiid(), poi.getMeshid(), poi.getOwner(), poi.getFeatcode(), poi.getSortcode(), poi.getNamec(),

poi.getNamee(), poi.getNamep(), poi.getNames()};

jdbcTemplate.update(sql, args);

}

}

B、用spring事务和springjdbc的batchUpdate

Java代码

081b1cfad599d6fed53deddf1068fe74.png

@Transactional("dbTransaction")

publicvoidbatchInsertJDBC2(List poilist)throwsDataAccessException {

String sql = "insert into tb_poi (tag, poi, poiid, meshid, owner, featcode, sortcode, namec, namee, namep, names) values (?, GeomFromText(?), ?, ?, ?, ?, ?, ?, ?, ?, ?)";

List batchArgs = newArrayList();

for(Poi poi : poilist) {

Object[] args = {poi.getTag(), poi.getPoint(), poi.getPoiid(), poi.getMeshid(), poi.getOwner(), poi.getFeatcode(), poi.getSortcode(), poi.getNamec(),

poi.getNamee(), poi.getNamep(), poi.getNames()};

batchArgs.add(args);

}

jdbcTemplate.batchUpdate(sql, batchArgs);

}

C、用spring事务,利用mysql特性,拼写insert sql。

Java代码

081b1cfad599d6fed53deddf1068fe74.png

@Transactional("dbTransaction")

publicvoidbatchInsertJDBC3(List poilist)throwsDataAccessException {

StringBuffer sqlbuf = newStringBuffer()

.append("insert into tb_poi (tag, poi, poiid, meshid, owner, featcode, sortcode, namec, namee, namep, names) values ");

MessageFormat form = newMessageFormat("(''{0}'', GeomFromText(''{1}''), ''{2}'', ''{3}'', ''{4}'', ''{5}'', ''{6}'', ''{7}'', ''{8}'', ''{9}'', ''{10}''),");

for(Poi poi : poilist) {

Object[] args = {poi.getTag(), poi.getPoint(), poi.getPoiid(), poi.getMeshid(), poi.getOwner(), poi.getFeatcode(), poi.getSortcode(), poi.getNamec().replaceAll("'","\\\\'"),

poi.getNamee().replaceAll("'","\\\\'"), poi.getNamep().replaceAll("'","\\\\'"), poi.getNames().replaceAll("'","\\\\'")};

sqlbuf.append(form.format(args));

}

String sql = sqlbuf.toString();

sql = sql.substring(0, sql.length()-1);

jdbcTemplate.update(sql);

}

测试一:每次处理100条,共600条。

测试二:每次处理1000条,共9000条。

直接上结论:

mybatis.1最慢。而且慢很多,很多。

mybatis.2很快。是mybatis中最快的。

mybatis.3比2慢一点。

jdbc.A比B稍快,两者差不多,和mybatis.3也在伯仲之间。

jdbc.C最快,比其他5种都快。

大排行,从用时少到用时多:

jdbc.C < mybatis.2 < jdbc.A < jdbc.B , mybatis.3 << mybatis.1

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

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

相关文章

mysql启动触发器_MYSQL中禁用/启动触发器

在使用MYSQL过程中&#xff0c;经常会使用到触发器&#xff0c;但是有时使用不当会造成一些麻烦。有没有一种办法可以控制触发器的调用呢&#xff1f;触发器顾名思义就是数据库在一定的调条件自动调用的SQL语句&#xff0c;触发器拒绝了人工调用的过程&#xff0c;由数据库MYSQ…

mysql数据库权威指南_MySQL_MySQL权威指南读书笔记(三),第二章:MYSQL数据库里面的数 - phpStudy...

MySQL权威指南读书笔记(三)第二章&#xff1a;MYSQL数据库里面的数据用想用好MYSQL&#xff0c;就必须透彻理解MYSQL是如何看待和处理数据的。本章主要讨论了两个问题&#xff1a;一是&#xff33;&#xff31;&#xff2c;所能处理的数据值的类型&#xff1b;二是这些数据类型…

mysql 批量替换 所有表_[收藏]批量替换一个数据库中所有表中所有记录

/***********批量替换一个数据库中所有表中所有记录************/declare delStr nvarchar(500)set delStr这里是要替换的字符/**********以下为操作实体************/set nocount ondeclare tableName nvarchar(100),columnName nvarchar(100),tbID int,iRow int,iResult intd…

java偶数和_Java编程计算1-100之间所有偶数的和。

展开全部 public class Demo05ShiCao{public static void main(String[] args){int sum1 = 0; for(int i = 1; i <= 100; i++){if(i % 2 == 0){sum1 +=i; } } System.out.println("结果e5a48de588b63231313335323631343130323136353331333366303138是:" + sum1);…

金额转换java_java金额转换

像商品价格&#xff0c;订单&#xff0c;结算都会涉及到一些金额的问题&#xff0c;为了避免精度丢失通常会做一些处理&#xff0c;常规的系统中金额一般精确到小数点后两位&#xff0c;也就是分&#xff1b;这样数据库在设计的时候金额就直接存储整型数据类型&#xff0c;前端…

java 栈 大小_java – JVM堆栈大小规范

Question, what does 1 MB stack size states in JVM as I have no idea what size a stack frame of?1 MB默认线程堆栈大小意味着每个线程默认具有1MB(1048576字节)的堆栈空间.例外情况是,如果您的代码使用其中一个Thread构造函数创建一个线程,您可以在其中提供堆栈大小参数.…

java bloomfilter_爬虫技术之——bloom filter(含java代码)

在爬虫系统中&#xff0c;在内存中维护着两个关于URL的队列&#xff0c;ToDo队列和Visited队列&#xff0c;ToDo队列存放的是爬虫从已经爬取的网页中解析出来的即将爬取的URL&#xff0c;但是网页是互联的&#xff0c;很可能解析出来的URL是已经爬取到的&#xff0c;因此需要VI…

java new对象 =null_在Java中将对象分配为null会影响垃圾回收吗?

通常&#xff0c;没有。但就像所有事情一样&#xff1a;这取决于。如今&#xff0c;Java中的GC非常好&#xff0c;所有内容都应该在不再可用后立即清理。这就是在为局部变量留下一个方法之后&#xff0c;以及当不再为字段引用类实例时。如果您知道它将继续引用&#xff0c;则只…

java php js_【javascript/PHP】当一个JavaScripter初次进入PHP的世界,他将看到这样的风景...

本文将从以下11点介绍javascript和PHP在基础语法和基本操作上的异同&#xff1a;1.数据类型的异同2.常量和变量的定义的不同&#xff0c;字符串连接运算符不同3.对象的创建方法的不同4.PHP与JS在变量声明提升和函数声明提升的差异5.var在JS和PHP中使用的差异6.PHP和JS在访问对象…

java so jnienv_JNI初步(五)jni ndk 一个.so文件依赖另一个.so文件的写法

注意&#xff1a;本文是在ndk环境下编写1.写native类声明native方法package com.godv.audiosuc;public class NativePlayers {static{System.loadLibrary("JNI_ANDROID_AUDIOS");System.loadLibrary("JNI_ANDROID_TEST");}//native方法public static nativ…

从零开始学java 框架_从零开始学 Java - 搭建 Spring MVC 框架

如果创建一个 Spring 项目Spring MVC 框架在 Java 的 Web 项目中应该是无人不知的吧&#xff0c;你不会搭建一个 Spring 框架&#xff1f;作为身为一个刚刚学习Java的我都会&#xff0c;如果你不会的话&#xff0c;那可真令人忧伤。1.在 MyEclipse 创建项目后&#xff0c;可以以…

java 系统类型_Java获取操作系统类型

Java获取操作系统完整版系统枚举类&#xff1a;public enum EPlatform {Any("any"),Linux("Linux"),Mac_OS("Mac OS"),Mac_OS_X("Mac OS X"),Windows("Windows"),OS2("OS/2"),Solaris("Solaris"),SunOS…

java的min函数_Java语言实现包含min函数的栈

package stack;import java.util.ArrayList;/*** 实现包含min函数的栈* author DHC* param */public class MinInStack {public static void main(String[] args) {MinInStack newStack new MinInStack();newStack.push(4);newStack.push(6);newStack.push(2);newStack.push(5…

updatepanel失效怎么办_【点滴积累】解决jQuery绑定事件在updatepanel更新后失效的方法...

背景 接到了领导给的一个New Feature&#xff0c;为系统的菜单导航栏进行一些个性化的操作(鼠标移到导航菜单时下方出现子菜单&#xff0c;移到其他的菜单选项时显示该选项的子菜单&#xff0c;隐藏其他子菜单。其次就是当使用鼠标点击一个菜单选项时就把该菜单及其子菜单固定&…

azure mysql on vnet_管理 VNet 终结点 - Azure 门户 - Azure Database for MySQL | Microsoft Docs

您现在访问的是微软AZURE全球版技术文档网站&#xff0c;若需要访问由世纪互联运营的MICROSOFT AZURE中国区技术文档网站&#xff0c;请访问 https://docs.azure.cn.使用 Azure 门户创建和管理 Azure Database for MySQL VNet 服务终结点和 VNet 规则Create and manage Azure D…

java excel api及详细教程_针对Java Excel API及详细教程

时在java开发中会操作excel表格&#xff0c;其实操作起来也特别简单。这里把前期操作步骤说一下&#xff0c;本文会简单的介绍一个开放源码项目&#xff1a;Java Excel Api&#xff0c;使用它大家就可以方便的操作Excel文件了。首先下载好&#xff1a;Java Excel Api&#xff0…

java jmap jc_利用jmap命令查看JVM内存使用详情

介绍打印出某个java进程(使用pid)内存内的&#xff0c;所有‘对象’的情况(如&#xff1a;产生那些对象&#xff0c;及其数量)。它的用途是为了展示java进程的内存映射信息&#xff0c;或者堆内存详情。可以输出所有内存中对象的工具&#xff0c;甚至可以将VM 中的heap&#xf…

雅居乐万豪酒店java_“万豪,我心所属之地” | 上海雅居乐万豪酒店Terence Sun的实习故事...

​我叫孙庭骏&#xff0c;来自台北&#xff0c;目前就读瑞士恺撒里兹酒店管理学院&#xff0c;在来上海之前曾在瑞士苏黎世万豪酒店的餐饮部实习过两次&#xff0c;共一年的时间&#xff0c;所以万豪对我来说并不陌生。万豪一直深深吸引我的莫过于它的核心价值以及非凡待客之道…

java quartz spring_JavaLib-quartz | 基于Spring Boot Quartz开发的定时任务

基于Spring Boot Quartz开发的JavaLib-quartz&#xff0c;目的是帮你快速构建定时任务系统&#xff0c;你可以专心编写你的业务逻辑&#xff0c;而不必关注定时任务具体是如何实现的&#xff0c;他的性能如何&#xff0c;有没有异常以及异常处理&#xff0c;监控等等问题。这些…

java static 加载顺序_一个例子搞清楚Java类加载顺序

当我们new一个GirlFriend时&#xff0c;我们都做了什么&#xff1f;一个例子搞懂Java程序运行顺序public class Girl {Person person new Person("Girl");static{System.out.println("Girl static");}static Person staticPerson new Person("GirlS…