我的应用程序使用JSON对象很多(org.json.JSONArray和朋友)。将它们存储到Mongo DBObjects以便查询它们的最有效方法是什么? BasicDBObject无法序列化JSONArray - 这两个层次之间似乎没有互操作性。在MongoDB中使用JSON?
18
A
回答
8
OK似乎没有互操作性,所以我滚动我自己的。繁忙的工作,以绕过类型系统:
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;
}
}
}
0
我不知道java mongo驱动程序,但在c# mongo driver有BsonSerializer类。 您可以使用它像下面的代码:
var q = BsonSerializer.Deserialize<MyDocument>("{ jsonValueName:jsonValue }");
PLZ检查mongo-java-driver,我感谢它应该包含相同的设施
28
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;
0
这个工作,并引发了一个问题,为什么Mongo人决定有一个对象返回类型而不是DBObject:有谁知道吗?
一个很好的选择是,如果你的应用程序中有很多JSON,将使用Jackson作为(反)序列化。
相关问题
- 1. Rails:在MongoDB中存储JSON
- 2. 在MongoDB中存储JSON
- 3. 在MongoDB中使用Scala - java.lang.NoClassDefFoundError:com/mongodb/DBObject
- 4. 在Python中使用JSON向MongoDB发送查询
- 5. 如何使用JSON在MongoDB中进行查询?
- 6. 使用JSON更新MongoDB文档
- 7. 在MongoDB中使用关系
- 8. 在mongodb中使用$ gt
- 9. 如何在MongoDB中查询JSON
- 10. 错误在MongoDB中JSON格式
- 11. 如何在MongoDB中存储泛型JSON?
- 12. 在mongodb中保留关系json
- 13. JSON树MongoDB
- 14. MongoDB - JSON解析
- 15. MongoDB的对象ID为JSON使用电梯,JSON
- 16. 如何使用python将JSON存储到mongodb中?
- 17. 使用变量将json文件插入到mongodb中
- 18. 我在哪里可以得到样本JSON数据在MongoDB中使用
- 19. 使用lift-json在scala中验证json
- 20. 使用php从mongodb导出json文件中的文档使用php
- 21. 如何在mongodb中插入JSON时避免引用
- 22. 使用mongodb与mongodb图集
- 23. 在Spring Data MongoDB中使用JSON文本文件的目的是什么?
- 24. 如何在MongoDB中使用MongoDB和传统数据库?
- 25. MongoDB在MongoDB中使用Mongoid in Rails - 地理空间索引
- 26. 如何使用node-mongodb-native游标在Mongodb中进行分页?
- 27. 今天在node.js连接中使用mongodb
- 28. 在Express路由器中使用mongoDB
- 29. 如何在MongoDB中使用$匹配
- 30. 使用PHP在MongoDB查询中订购
是的,我可以序列化为一个字符串并反序列化字符串,但我试图互操作本地对象。不过谢谢。 – Simon 2011-05-04 00:53:41