程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> [記錄]千萬數據存入mysql

[記錄]千萬數據存入mysql

編輯:MySQL綜合教程

[記錄]千萬數據存入mysql   存入1千萬條數據,用hibernate存 數據的定義都很簡單:

Sql代碼  
create table testEntity2 (  
    id varchar(255) not null,  
    description varchar(255),  
    name varchar(255),  
    primary key (id)  
)  

 

 主鍵生成策略UUID   防止數據過大  設置  <property name="hibernate.jdbc.batch_size">50</property>  同時代碼裡也是50次 flush一下 clear一下 在eclipse的環境中 內存占用在500M左右   每10w條打印一次 如果不使用batch_size 也不flush和clear 內存會在2G左右 並且也會發生內存溢出的錯誤:(但前面幾次的速度非常可觀 到第280萬條的時候堆溢出) 但這些只是存在session的緩存裡 沒有真正uncommit到數據庫 所以到底有多快...不好說... 正在插入  
1:1  
2:2  
3:2  
4:3  
5:3  
6:5  
7:5  
8:7  
9:7  
10:7  
11:8  
12:8  
13:8  
14:11  
15:11  
16:11  
17:12  
18:15  
19:15  
20:15  
21:16  
22:16  
23:17  
24:17  
25:24  
26:28  
27:35  
28:49  
Exception in thread "main" java.lang.OutOfMemoryError: GC overhead limit exceeded  
    at org.hibernate.engine.internal.StatefulPersistenceContext.addEntry(StatefulPersistenceContext.java:539)  
    at org.hibernate.event.internal.AbstractSaveEventListener.performSaveOrReplicate(AbstractSaveEventListener.java:249)  
    at org.hibernate.event.internal.AbstractSaveEventListener.performSave(AbstractSaveEventListener.java:192)  
    at org.hibernate.event.internal.AbstractSaveEventListener.saveWithGeneratedId(AbstractSaveEventListener.java:135)  
    at org.hibernate.event.internal.DefaultSaveOrUpdateEventListener.saveWithGeneratedOrRequestedId(DefaultSaveOrUpdateEventListener.java:206)  
    at org.hibernate.event.internal.DefaultSaveEventListener.saveWithGeneratedOrRequestedId(DefaultSaveEventListener.java:55)  
    at org.hibernate.event.internal.DefaultSaveOrUpdateEventListener.entityIsTransient(DefaultSaveOrUpdateEventListener.java:191)  
    at org.hibernate.event.internal.DefaultSaveEventListener.performSaveOrUpdate(DefaultSaveEventListener.java:49)  
    at org.hibernate.event.internal.DefaultSaveOrUpdateEventListener.onSaveOrUpdate(DefaultSaveOrUpdateEventListener.java:90)  
    at org.hibernate.internal.SessionImpl.fireSave(SessionImpl.java:764)  
    at org.hibernate.internal.SessionImpl.save(SessionImpl.java:756)  
    at org.hibernate.internal.SessionImpl.save(SessionImpl.java:752)  
    at org.cc.data.test.DataGenerator.main(DataGenerator.java:25)  

 

  然後分別做一下測試 先把batch_size設置為10 每10次 flush和clear: 正在插入 1:37 2:72 3:108 4:144 .......  50和100的測試和這個結果也大同小異就不測試了   其他的以後再寫了..  

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved