使用JSON与MongoDB?

18

我的应用程序经常使用JSON对象(org.json.JSONArray等)。将它们存储到Mongo DBObjects中以便进行查询的最有效方法是什么?BasicDBObject无法序列化JSONArray - 这两个层次结构之间似乎没有互操作性。

4个回答

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;

com.mongodb.util.JSON已被弃用。 - kai

8

好的,看起来没有互操作性,所以我自己写了一个。为了绕开类型系统而进行的繁琐工作:

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 Driver,但在C# Mongo Driver中有BsonSerializer类。您可以像以下代码一样使用它:

var q = BsonSerializer.Deserialize<MyDocument>("{ jsonValueName:jsonValue }"); 

请查看mongo-java-driver,我认为它应该包含相同的功能。
还要看看bson4jackson

是的,我可以将其序列化为字符串并反序列化该字符串,但我正在尝试与本地对象进行交互。不过还是谢谢。 - Simon

0

这个代码可以运行,但是我们不知道Mongo的开发者为什么决定采用Object返回类型而非DBObject,是否有人知道原因?

如果你的应用中有大量的JSON数据,使用Jackson进行反序列化和序列化可能是一个很好的选择。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接