gpt4 book ai didi

java - 将更多记录写入 berkeleyDB 时出现问题

转载 作者:太空宇宙 更新时间:2023-11-04 08:34:57 24 4
gpt4 key购买 nike

i am using berkeley DB JE 4.1.10i have use the secondary database concept and I want to insert 10,00,000 rows to the database .i am getting following errorException in thread "main" com.sleepycat.je.EnvironmentFailureException: (JE 4.1.10) JAVA_ERROR: Java Error occurred, recovery may not be possible.at com.sleepycat.je.dbi.EnvironmentImpl.checkIfInvalid(EnvironmentImpl.java:1450)at com.sleepycat.je.Transaction.checkEnv(Transaction.java:756)at com.sleepycat.je.Transaction.abort(Transaction.java:105)at WriteDataUsingCursor.main(WriteDataUsingCursor.java:90)Caused by: java.lang.OutOfMemoryError: Java heap spacei have set the following parameter for environment and databaseEnvironment env=null;Database primarydb=null;SecondaryDatabase secondarydb=null;@SuppressWarnings("rawtypes")TupleBinding mybinding=null;String firstdb="CDRFirstDatabase";String seconddb = "CDRSecondDatabase";public void setupenvironment(){try{// EnvironmentFile dbpath = new File("W:/dhananjay/workspace/BDB-SecondaryDatabase(JEAPI)-SmaxCDR/src/DB1");EnvironmentConfig envconfig = new EnvironmentConfig();envconfig.setAllowCreate(true);envconfig.setTransactional(true);env = new Environment(dbpath,envconfig);// Primary DatabaseDatabaseConfig dbconfig = new DatabaseConfig();dbconfig.setAllowCreate(true);dbconfig.setTransactional(true);dbconfig.setSortedDuplicates(false);primarydb = env.openDatabase(null, firstdb, dbconfig);// Secondary DatabaseSecondaryConfig secondarydbconfig = new SecondaryConfig();secondarydbconfig.setAllowCreate(true);secondarydbconfig.setTransactional(true);secondarydbconfig.setSortedDuplicates(true);// Create Key for secondary DBmybinding = new MyTupleBinding();SecondaryKey keycreator = new SecondaryKey(mybinding);secondarydbconfig.setKeyCreator(keycreator);secondarydb = env.openSecondaryDatabase(null, seconddb, primarydb, secondarydbconfig);}catch(Exception e){System.out.println("Error----->"+e);}}i am using following code to insert the data into databaseDBEnvironment dbenv = new DBEnvironment();DatabaseEntry theKey = new DatabaseEntry();DatabaseEntry theData = new DatabaseEntry();@SuppressWarnings("unchecked")public static void main(String[] args){Cursor cursor = null;Transaction txn=null;dbenv.setupenvironment();try{txn = dbenv.getEnv().beginTransaction(null, null);cursor = dbenv.getPrimaryDB().openCursor(txn, null);String line = null;BufferedReader br = new BufferedReader( new FileReader("W:/dhananjay/workspace/SMAXCDR/110618_154501.cdr"));long startTime = System.currentTimeMillis();while((line = br.readLine()) != null){String[] sArray = line.split(",");CDRData cdrfile = new CDRData();theKey = new DatabaseEntry(sArray[0].getBytes("UTF-8"));cdrfile.setId(sArray[0]);cdrfile.setCallTime(sArray[1]);cdrfile.setDisconnectTime(sArray[2]);cdrfile.setIngressTrunkID(sArray[3]);cdrfile.setIngressSignalingIP(sArray[4]);cdrfile.setIngressMediaIP(sArray[5]);cdrfile.setEgressTrunkID(sArray[6]);cdrfile.setEgressSignalingIP(sArray[7]);cdrfile.setEgressMediaIP(sArray[8]);cdrfile.setANI(sArray[9]);cdrfile.setDNID(sArray[10]);cdrfile.setDNID_with_IngressPrefix(sArray[11]);cdrfile.setDNID_with_EgressPrefix(sArray[12]);cdrfile.setCodeMatch(sArray[13]);cdrfile.setProtocol(sArray[14]);cdrfile.setCallID(sArray[15]);cdrfile.setSMaxCallID(sArray[16]);cdrfile.setRingDuration(sArray[17]);cdrfile.setPDDDuration(sArray[18]);cdrfile.setRawDuration(sArray[19]);cdrfile.setCauseCode(sArray[20]);cdrfile.setTFlag(sArray[21]);cdrfile.setRFlag(sArray[22]);dbenv.getBinding().objectToEntry(cdrfile, theData);cursor.put(theKey, theData);}cursor.close();txn.commit();dbenv.close();long finishTime = System.currentTimeMillis();System.out.println("The time taken by insert query : "(finishTime-startTime) " ms");System.out.println("Record Inserted");}

最佳答案

游标和事务会保留在内存中,直到它们被关闭/提交。您需要分批插入,也许 1000 个。对于每个批处理,完成后关闭游标,提交事务,然后为下一个批处理创建新的事务。

关于java - 将更多记录写入 berkeleyDB 时出现问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6625135/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com