Hibernate入門:批量插入資料

來源:互聯網
上載者:User

一般如果要插入100萬條資料,則會寫如下代碼:

package org.xiazdong.test;import junit.framework.TestCase;import org.hibernate.Session;import org.hibernate.SessionFactory;import org.hibernate.Transaction;import org.hibernate.cfg.Configuration;import org.junit.Test;import org.xiazdong.Person;public class PersonTest extends TestCase{@Testpublic void testAdd(){long begin = System.currentTimeMillis();Configuration config = new Configuration();config.configure();SessionFactory factory = config.buildSessionFactory();Session session = factory.openSession(); Transaction tx = session.beginTransaction();   for ( int i=0; i<1000000; i++ ) { //插入100萬條資料Person person = new Person("xiazdong-"+i,i+20);     session.save(person); }   tx.commit(); session.close();long end = System.currentTimeMillis();System.out.println((end-begin)/1000.0);}}

此程式正常來說是會報錯:

 

這是因為Hibernate預設會把沒有提交的資料全部緩衝,但是緩衝是不能存入100萬條資料的,因此會報錯,我們怎麼樣能夠解決呢?

我們可以通過每100個insert語句時,就強制刷入資料庫,實現代碼如下:

package org.xiazdong.test;import junit.framework.TestCase;import org.hibernate.Session;import org.hibernate.SessionFactory;import org.hibernate.Transaction;import org.hibernate.cfg.Configuration;import org.junit.Test;import org.xiazdong.Person;public class PersonTest extends TestCase{@Testpublic void testAdd(){long begin = System.currentTimeMillis();Configuration config = new Configuration();config.configure();SessionFactory factory = config.buildSessionFactory();Session session = factory.openSession(); Transaction tx = session.beginTransaction();   for ( int i=0; i<1000000; i++ ) { //插入100萬條資料Person person = new Person("xiazdong-"+i,i+20);     session.save(person);     if(i%100==0){//每一千條重新整理並寫入資料庫    session.flush();    session.clear();    }}tx.commit(); session.close();long end = System.currentTimeMillis();System.out.println((end-begin)/1000.0);}}

經過測試,花費時間為:148秒;

註:如果資料庫在程式執行過程中記錄數為0,是因為資料庫為read commited,事務提交之後才能夠資料。

 

當然,同樣可以使用Hibernate配置來實現同樣功能:

在hibernate.cfg.xml中插入:

<property name="hibernate.jdbc.batch_size">50</property>//每50條語句提交一次 <property name="hiberante.cache.use_second_level_cache">false</property>//關閉二級緩衝 

 

 

 

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.