我的应用程序经常使用JSON对象(org.JSON.JSONArray和friends).将这些存储到Mongo DBObjects中以便查询它们的最有效方法是什么?BasicDBObject无法序列化JSONArray——这两个层次 struct 之间似乎根本没有互操作性.
我的应用程序经常使用JSON对象(org.JSON.JSONArray和friends).将这些存储到Mongo DBObjects中以便查询它们的最有效方法是什么?BasicDBObject无法序列化JSONArray——这两个层次 struct 之间似乎根本没有互操作性.
好吧,似乎没有互操作性,所以我推出了自己的.绕过类型系统的繁忙工作:
public class Util {
public static DBObject encode(JSONArray a) {
BasicDBList result = new BasicDBList();
try {
for (int i = 0; i < a.length(); ++i) {
Object o = a.get(i);
if (o instanceof JSONObject) {
result.add(encode((JSONObject)o));
} else if (o instanceof JSONArray) {
result.add(encode((JSONArray)o));
} else {
result.add(o);
}
}
return result;
} catch (JSONException je) {
return null;
}
}
public static DBObject encode(JSONObject o) {
BasicDBObject result = new BasicDBObject();
try {
Iterator i = o.keys();
while (i.hasNext()) {
String k = (String)i.next();
Object v = o.get(k);
if (v instanceof JSONArray) {
result.put(k, encode((JSONArray)v));
} else if (v instanceof JSONObject) {
result.put(k, encode((JSONObject)v));
} else {
result.put(k, v);
}
}
return result;
} catch (JSONException je) {
return null;
}
}
}