Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/json/13.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 在MongoDB中使用JSON?_Java_Json_Mongodb - Fatal编程技术网

Java 在MongoDB中使用JSON?

Java 在MongoDB中使用JSON?,java,json,mongodb,Java,Json,Mongodb,我的应用程序经常使用JSON对象(org.JSON.JSONArray和friends)。将这些存储到Mongo DBObjects中以便查询它们的最有效方法是什么?BasicDBObject无法序列化JSONArray——这两个层次结构之间似乎根本没有互操作性。我不知道java mongo驱动程序,但在BsonSerializer类中。 您可以像以下代码一样使用它: var q = BsonSerializer.Deserialize<MyDocument>("{ jsonValu

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

我不知道java mongo驱动程序,但在BsonSerializer类中。 您可以像以下代码一样使用它:

var q = BsonSerializer.Deserialize<MyDocument>("{ jsonValueName:jsonValue }"); 
var q=BsonSerializer.Deserialize(“{jsonValueName:jsonValue}”);
请检查,我感谢它应该包含相同的设施


另请看

好的,似乎没有互操作性,所以我推出了自己的。围绕类型系统进行的忙碌工作:

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;
        }
    }
}
公共类Util{
公共静态DBObject编码(JSONArray a){
BasicDBList结果=新建BasicDBList();
试一试{
对于(int i=0;i
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;

这是可行的,并引发了一个问题,即为什么Mongo人决定使用对象返回类型而不是DBObject:有人知道吗


如果你的应用程序中有很多JSON,一个好的替代方法是使用(反)序列化。

是的,我可以序列化为字符串并反序列化字符串,但我正在尝试互操作本机对象。谢谢,不过不推荐使用.com.mongodb.util.JSON