【发布时间】:2011-04-18 06:34:28
【问题描述】:
我的应用程序大量使用 JSON 对象(org.json.JSONArray 和朋友)。将这些存储到 Mongo DBObjects 以便可以查询它们的最有效方法是什么? BasicDBObject 无法序列化 JSONArray——这两个层次结构之间似乎根本没有互操作性。
【问题讨论】:
我的应用程序大量使用 JSON 对象(org.json.JSONArray 和朋友)。将这些存储到 Mongo DBObjects 以便可以查询它们的最有效方法是什么? BasicDBObject 无法序列化 JSONArray——这两个层次结构之间似乎根本没有互操作性。
【问题讨论】:
com.mongodb.util.JSON 具有将 JSON 字符串解析为 DBObject 的方法。 默认的 JSONCallback 会根据输入的字符串返回 BasicDBObject 或 BasicDBList。
Object jsonObj = ...; //any of your org.json objects
Object o = com.mongodb.util.JSON.parse(jsonObj.toString());
DBObject dbObj = (DBObject) o;
【讨论】:
好吧,似乎没有互操作性,所以我推出了自己的。忙于绕过类型系统:
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;
}
}
}
【讨论】:
我不了解 java mongo 驱动程序,但在 c# mongo driver 中有 BsonSerializer 类。 您可以像下面的代码一样使用它:
var q = BsonSerializer.Deserialize<MyDocument>("{ jsonValueName:jsonValue }");
请检查mongo-java-driver,谢谢它应该包含相同的设施
【讨论】:
这行得通,并提出了一个问题,即为什么 Mongo 人决定使用 Object 返回类型而不是 DBObject:有人知道吗?
如果您的应用中有大量 JSON,一个不错的选择是使用 Jackson 进行(反)序列化。
【讨论】: