Мое приложение много использует объекты JSON (org.json.JSONArray и друзей). Каков наиболее эффективный способ их хранения в Mongo DBObjects, чтобы их можно было запросить? BasicDBObject не может сериализовать JSONArray - похоже, взаимодействия между этими двумя иерархиями вообще не существует.
Использование JSON с MongoDB?
Ответ 1
ОК, похоже, что нет совместимости, поэтому я откатился. Занятие, чтобы обойти систему типов:
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;
}
}
}
Ответ 2
com.mongb.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;
Ответ 3
Я не знаю о java mongo driver, но в С# mongo driver имеет класс BsonSerializer. Вы можете использовать его, как следующий код:
var q = BsonSerializer.Deserialize<MyDocument>("{ jsonValueName:jsonValue }");
plz check mongo-java-driver, я благодарю, что он должен содержать те же возможности
также посмотрите bson4jackson
Ответ 4
Это работает и ставит вопрос о том, почему монгольские люди решили использовать тип возвращаемого объекта вместо DBObject: кто-нибудь знает?
Хорошей альтернативой, если у вас много JSON в вашем приложении, было бы использовать Jackson для сериализации (de).