Spring 批量insert 效率问题

背景

  • 使用框架spring mvc
  • dao层用到是的spring jdbc

namedParameterJdbcTemplate batchUpdate 批量

  • 具体代码如下
	public void testBatch(int count){
		String sqlStr ="INSERT INTO C_DSS_BASE_INP_SETTLE (\n" +
				"	ORG_ID,\n" +
				"	PK_HIS,\n" +
				"	SETTLING_DATETIME,\n" +
				"	ORDERED_BY,\n" +
				"	PERFORMED_BY,\n" +
				"	DEPT_DISCHARGE_FROM,\n" +
				"	ITEM_CLASS,\n" +
				"	COSTS,\n" +
				"	CHARGES,\n" +
				"	CREATE_TIME,\n" +
				"	DATA_TIME\n" +
				")\n" +
				"VALUES\n" +
				"	(\n" +
				"		:ORG_ID,\n" +
				"		:PK_HIS,\n" +
				"		:SETTLING_DATETIME,\n"+
				"		:ORDERED_BY,\n" +
				"		:PERFORMED_BY,\n" +
				"		:DEPT_DISCHARGE_FROM,\n" +
				"		:ITEM_CLASS,\n" +
				"		:COSTS,\n" +
				"		:CHARGES,\n" +
				"		:CREATE_TIME,\n" +
				"		:DATA_TIME\n" +
				"	)";
		SqlParameterSource[] params = new MapSqlParameterSource[count];
		for (int i = 0; i < count; i++) {
			MapSqlParameterSource param = new MapSqlParameterSource();
			param.addValue("ORG_ID", "290001");
			param.addValue("PK_HIS", "2016-07-14 00:00:00");
			param.addValue("SETTLING_DATETIME", "2016-07-14 00:00:00");
			param.addValue("ORDERED_BY", "1000");
			param.addValue("PERFORMED_BY", "600A");
			param.addValue("DEPT_DISCHARGE_FROM", "3401");
			param.addValue("ITEM_CLASS", "3401");
			param.addValue("COSTS", "5.34");
			param.addValue("CHARGES", "5.34");
			param.addValue("CREATE_TIME", "2016-07-14 14:23:43");
			param.addValue("DATA_TIME", "2016-07-14 14:23:43");
			params[i] = param;
		}
		namedParameterJdbcTemplate.batchUpdate(sqlStr,params);
	}
  • 10000条平均需要290s左右

使用拼接SQL方式方式批量操作

  • 拼接方式如下
insert  test (....)  values(),(),().......();
  • 具体代码如下
StringBuilder builder = new StringBuilder("INSERT INTO C_DSS_BASE_INP_SETTLE (\n" +
				"	ORG_ID,\n" +
				"	PK_HIS,\n" +
				"	SETTLING_DATETIME,\n" +
				"	ORDERED_BY,\n" +
				"	PERFORMED_BY,\n" +
				"	DEPT_DISCHARGE_FROM,\n" +
				"	ITEM_CLASS,\n" +
				"	COSTS,\n" +
				"	CHARGES,\n" +
				"	CREATE_TIME,\n" +
				"	DATA_TIME\n" +
				") VALUES  \n" );
		for (int i = 0; i <count; i++) {
			builder.append(
					" \n" +
					"	(\n" +
					"		'290001',\n" +
					"		'2016-07-14 00:00:00',\n" +
					"		'2016-07-14 00:00:00',\n" +
					"		'1000' ,\n" +
					"		'600A' ,\n" +
					"		'3401' ,\n" +
					"		'A',\n" +
					"		'5.34',\n" +
					"		'5.34',\n" +
					"		'2016-07-14 14:23:43',\n" +
					"		'2016-07-14 14:23:43'\n" +
					"	),");
		}
		String sqlStr = builder.toString();
		sqlStr = sqlStr.substring(0, sqlStr.length()-1);
		namedParameterJdbcTemplate.getJdbcOperations().update(sqlStr);
  • 10000条平均需要1s左右

结论

两种方式差距相当大,故批量操作建议使用第二种,不过至于为第二种效率高,
本菜鸟还需要进一步研究下,如果有知道原因的大神请指教哈。

转载于:https://my.oschina.net/CPFspace/blog/808050

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
根据表格数据批量生成Insert Into语句 本人在登陆CSDN论坛的数据库板块时,常看到很多网友提关于数据库的各种问题。而这些问题中有很多是要使用范例数据的。但是很多提问的朋友却没有把这些范例数据库INSERT INTO语句写出来,只是以这种方式提供:id dates num1 num2---------------------------------------------------------0001 2004-4-5 2000 3000 0002 2004-4-5 1000 5000 0003 2005-6-7 1500 3000 0004 2006-5-6 1200 3000 0005 2005-6-7 1300 3400 对于回答问题网友来说,见表和构建INSERT INTO语句是很费时间的,很多时候用于这里的时间比写出要求的SQL语句用的时间还多,其不是对答题网友时间的及大浪费。现在这种状况可以得到改善了。本人利用空余时间写了个小程序strfmt.exe,它可以批量将上面或类似的数据一次性生成INSERT INTO # VALUES语句,如INSERT INTO # VALUES ('0001','2004-4-5','2000','3000')INSERT INTO # VALUES ('0002','2004-4-5','1000','5000')INSERT INTO # VALUES ('0003','2005-6-7','1500','3000')INSERT INTO # VALUES ('0004','2006-5-6','1200','3000')INSERT INTO # VALUES ('0005','2005-6-7','1300','3400')或者生成INSERT INTO # SELECT语句,如INSERT INTO # SELECT '0001','2004-4-5','2000','3000'INSERT INTO # SELECT '0002','2004-4-5','1000','5000'INSERT INTO # SELECT '0003','2005-6-7','1500','3000'INSERT INTO # SELECT '0004','2006-5-6','1200','3000'INSERT INTO # SELECT '0005','2005-6-7','1300','3400'有了strfmt.exe,广大答题者就能大大提高答题效率,不必浪费时间在范例数据的构建上了。 本程序只是本人业余之作,没有进行系统性的测试,希望用户能反馈出现的问题。程序存在已知问题如不能区分形如2007-11-13 12:12:00:564这种日期和时间中间有空格的字段,程序会把它们当成两个字段。在未来的改进版本中将处理这个问题。希望用户提出本程序的改进建议,本人不胜感激!联系邮箱:internetroot@hotmail.com
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值