大量数据情况下单线程插入和多线程insert数据库的性能测试

        之前一直没有遇到过大批量数据入库的场景,所以一直没有思考过在大量数据的情况下单线程插入和多线程插入的性能情况。今天在看一个项目源代码的时候发现使用了多线程insert操作。

于是简单的写了一个测试程序来测试一批数据在N个线程下的insert情况。

public class ThreadImport {
	private String url="jdbc:oracle:thin:@localhost:1521:orcl";
	private String user="cmis";
	private String password="cmis";
	public Connection getConnect(){
		Connection con = null;
		 try {
			Class.forName("oracle.jdbc.driver.OracleDriver");
			con=DriverManager.getConnection(url, user, password);  
		} catch (Exception e) {
			e.printStackTrace();
		}  
		 return con;
	}
	public void multiThreadImport( final int ThreadNum){
		final CountDownLatch cdl= new CountDownLatch(ThreadNum);
		long starttime=System.currentTimeMillis();
		for(int k=1;k<=ThreadNum;k++){
			new Thread(new Runnable() {
				@Override
				public void run() {
					Connection con=getConnect();
					try {
						Statement st=con.createStatement();
						for(int i=1;i<=80000/ThreadNum;i++){
							String uuid=UUID.randomUUID().toString();
							st.addBatch("insert into demo_table(a,b) values('"+uuid+"','"+uuid+"')");
							if(i%500==0){
								st.executeBatch();
							}
						}
						cdl.countDown();
					} catch (Exception e) {
					}finally{
						try {
							con.close();
						} catch (SQLException e) {
							e.printStackTrace();
						}
					}
				}
			}).start();
		}
		try {
			cdl.await();
			long spendtime=System.currentTimeMillis()-starttime;
			System.out.println( ThreadNum+"个线程花费时间:"+spendtime);
		} catch (InterruptedException e) {
			e.printStackTrace();
		}
	
	}
	
	
	
	public static void main(String[] args) throws Exception {
		ThreadImport ti=new ThreadImport();
		ti.multiThreadImport(1);
		ti.multiThreadImport(5);
		ti.multiThreadImport(8);
		ti.multiThreadImport(10);
		ti.multiThreadImport(20);
		ti.multiThreadImport(40);
		System.out.println("笔记本CPU数:"+Runtime.getRuntime().availableProcessors());
	}
	
	

}

运行结果:

1个线程花费时间:56707
5个线程花费时间:21688
8个线程花费时间:16625
10个线程花费时间:16098
20个线程花费时间:19882
40个线程花费时间:23536
笔记本CPU数:8

发现在一定数量的线程下性能提升的还是很明显。

在实际的项目中,使用了连接池的情况下,多线程(在一定范围内)数据插入的性能还要明显一点。



转载于:https://my.oschina.net/caiw/blog/376420

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值