私のアプリケーションはJSONオブジェクトをよく使用します(org.json.JSONArrayとその仲間)。これらをMongoDBObjectsに保存して、クエリできるようにする最も効率的な方法は何ですか? BasicDBObjectはJSONArrayをシリアル化できません。これら2つの階層間に相互運用性はまったくないようです。
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;
}
}
}
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ではなくObjectの戻り値の型を使用することにした理由について質問を投げかけます。誰か知っていますか?
アプリにJSONがたくさんある場合は、(逆)シリアル化に Jackson を使用することをお勧めします。
Java mongoドライバーについてはわかりませんが、 c#mongoドライバー にはBsonSerializerクラスがあります。次のコードのように使用できます。
var q = BsonSerializer.Deserialize<MyDocument>("{ jsonValueName:jsonValue }");
plz check mongo-Java-driver 、同じ機能が含まれている必要があることに感謝します
bson4jackson も見てください