Используете JSON с MongoDB? - PullRequest
       4

Используете JSON с MongoDB?

18 голосов
/ 18 апреля 2011

Мое приложение часто использует объекты JSON (org.json.JSONArray и друзья). Какой самый эффективный способ сохранить их в Mongo DBObjects, чтобы их можно было запрашивать? BasicDBObject не может сериализовать JSONArray - кажется, что между этими двумя иерархиями вообще нет возможности взаимодействия.

Ответы [ 4 ]

28 голосов
/ 06 сентября 2011

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;
8 голосов
/ 19 апреля 2011

ОК, похоже, что взаимодействия нет, поэтому я покатил свой.Занятая работа, чтобы обойти систему типов:

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 голосов
/ 16 декабря 2012

Это работает, и возникает вопрос, почему люди из Монго решили использовать тип возвращаемого объекта вместо DBObject: кто-нибудь знает?

Хорошая альтернатива, если у вас много JSON вваше приложение будет использовать Джексона для (де) сериализации.

0 голосов
/ 18 апреля 2011

я не знаю о драйвере java mongo, но в c # mongo driver имеет класс BsonSerializer.Вы можете использовать его как следующий код:

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

PLZ Check Mongo-Java-драйвер , я благодарю, что он должен содержать те же средства

также посмотрите на bson4jackson

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...