最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

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

来源:懂视网 责编:小采 时间:2020-11-09 20:43:41
文档

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

使用JDBC在MySQL数据库中如何快速批量插入数据:使用JDBC连接MySQL数据库进行数据插入的时候,特别是大批量数据连续插入(10W+),如何提高效率呢? 在JDBC编程接口中Statement 有两个方法特别值得注意: void addBatch() throws SQLException Adds a set of parameter
推荐度:
导读使用JDBC在MySQL数据库中如何快速批量插入数据:使用JDBC连接MySQL数据库进行数据插入的时候,特别是大批量数据连续插入(10W+),如何提高效率呢? 在JDBC编程接口中Statement 有两个方法特别值得注意: void addBatch() throws SQLException Adds a set of parameter

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

在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()。

package cyl.demo.ipsearcher; 
 
import java.io.BufferedReader; 
import java.io.FileInputStream; 
import java.io.IOException; 
import java.io.InputStreamReader; 
import java.sql.Connection; 
import java.sql.DriverManager; 
import java.sql.PreparedStatement; 
import java.sql.SQLException; 
 
public class DbStoreHelper { 
 
 private String insert_sql; 
 private String charset; 
 private boolean debug; 
 
 private String connectStr; 
 private String username; 
 private String password; 
 
 public DbStoreHelper() { 
 connectStr = "jdbc:mysql://localhost:3306/db_ip"; 
 // connectStr += "?useServerPrepStmts=false&rewriteBatchedStatements=true"; 
 insert_sql = "INSERT INTO tb_ipinfos (iplong1,iplong2,ipstr1,ipstr2,ipdesc) VALUES (?,?,?,?,?)"; 
 charset = "gbk"; 
 debug = true; 
 username = "root"; 
 password = "***"; 
 } 
 
 public void storeToDb(String srcFile) throws IOException { 
 BufferedReader bfr = new BufferedReader(new InputStreamReader(new FileInputStream(srcFile), charset)); 
 try { 
 doStore(bfr); 
 } catch (Exception e) { 
 e.printStackTrace(); 
 } finally { 
 bfr.close(); 
 } 
 } 
 
 private void doStore(BufferedReader bfr) throws ClassNotFoundException, SQLException, IOException { 
 Class.forName("com.mysql.jdbc.Driver"); 
 Connection conn = DriverManager.getConnection(connectStr, username,password); 
 conn.setAutoCommit(false); // 设置手动提交 
 int count = 0; 
 PreparedStatement psts = conn.prepareStatement(insert_sql); 
 String line = null; 
 while (null != (line = bfr.readLine())) { 
 String[] infos = line.split(";"); 
 if (infos.length < 5) continue; 
 if (debug) { 
 System.out.println(line); 
 } 
 psts.setLong(1, Long.valueOf(infos[0])); 
 psts.setLong(2, Long.valueOf(infos[1])); 
 psts.setString(3, infos[2]); 
 psts.setString(4, infos[3]); 
 psts.setString(5, infos[4]); 
 psts.addBatch(); // 加入批量处理 
 count++; 
 } 
 psts.executeBatch(); // 执行批量处理 
 conn.commit(); // 提交 
 System.out.println("All down : " + count); 
 conn.close(); 
 } 
 
} 

执行完成以后:

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

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

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

在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 : 103498 
Convert finished. 
All spend time/s : 10 

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

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

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

使用JDBC在MySQL数据库中如何快速批量插入数据:使用JDBC连接MySQL数据库进行数据插入的时候,特别是大批量数据连续插入(10W+),如何提高效率呢? 在JDBC编程接口中Statement 有两个方法特别值得注意: void addBatch() throws SQLException Adds a set of parameter
推荐度:
标签: 批量 插入 my
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top