使用java中的couchdb4j api将批量文档保存到couchdb时发生java.lang.NullPointerException

时间:2012-05-15 07:57:50

标签: java database nosql couchdb

我尝试保存包含大约1,30,000条记录的文档,并使用bulksavedocument方法保存文档,但是我收到以下错误

 java.lang.NullPointerException
at com.fourspaces.couchdb.Database.bulkSaveDocuments(Database.java:280)

以下是我用来保存批量文档的代码。

JSONArray json=new JSONArray(); 
Document[] newdoc = null;
newdoc = new Document[json.size()];                      
for(int i=0;i<json.size();i++)
{
    Document singleDoc = new Document(json.getJSONObject(i));
    newdoc[i]=singleDoc;
}         
Session s = new Session("localhost",5984);
Database db = s.getDatabase("test"); 

db.bulkSaveDocuments(newdoc);

当我尝试调试程序以及源代码时出现以下错误

   net.sf.json.JSONException: A JSONArray text must start with '[' at character 1 of {"db_name":"item_masters_test","doc_count":0,"doc_del_count":0,"update_seq":0,"purge_seq":0,"compact_running":false,"disk_size":79,"instance_start_time":"1337249297703950","disk_format_version":5,"committed_update_seq":0}
at net.sf.json.util.JSONTokener.syntaxError(JSONTokener.java:499)
at net.sf.json.JSONArray._fromJSONTokener(JSONArray.java:1116)
at net.sf.json.JSONArray._fromString(JSONArray.java:1197)
at net.sf.json.JSONArray.fromObject(JSONArray.java:127)
at net.sf.json.JSONArray.fromObject(JSONArray.java:105)
at com.fourspaces.couchdb.CouchResponse.getBodyAsJSONArray(CouchResponse.java:129)
at com.fourspaces.couchdb.Database.bulkSaveDocuments(Database.java:282)
at ItemMasterTest4.main(ItemMasterTest4.java:565)

请建议解决此问题的解决方案。

1 个答案:

答案 0 :(得分:1)

我不太了解这个JSON lib,但是这个

JSONArray json=new JSONArray(); 

可能是一个大小为0(空)的数组。

所以你的循环以索引0进入,这不存在。所以

json.getJSONObject(i)

可以返回null。


你写这个的地方

for(int i=0;i<json.size();i++)

你可能意味着

for(int i=0;i<json.size()-1;i++)