sql >> データベース >  >> NoSQL >> MongoDB

MongoDBを使用してアレイを更新します

    次のドキュメントをコレクションに挿入しようとしているため、save()メソッドが失敗します:{"$ push":{"resources":[リソースのリスト]}}、および"$push"は有効なキーではありません名前。

    あなたの質問から、「itemList」内の{"itemID":"1"}に一致する埋め込みドキュメント内の埋め込みドキュメントのリスト"resources"に別のリソースドキュメントを追加しようとしているように見えます。これは正しいですか?

    埋め込まれたドキュメントのレイヤーを処理するのは難しいですが、それは可能です。
    JSシェルを使用して次のドキュメントを「リソース」リストに挿入する方法は次のとおりです。

    > var docToInsert = { "resourceID" : "3", "resourceName" : "Foo Test3"}
    > db.myCollection.update({_id:"1", "itemList.itemID":"1"}, {"$push":{"itemList.$.resources":docToInsert}})
    > db.myCollection.find().pretty()
    {
        "_class" : "com.model.Test",
        "_id" : "1",
        "itemList" : [
            {
                "itemID" : "1",
                "itemName" : "Foo",
                "resources" : [
                    {
                        "resourceID" : "1",
                        "resourceName" : "Foo Test1"
                    },
                    {
                        "resourceID" : "2",
                        "resourceName" : "Foo Test2"
                    },
                    {
                        "resourceID" : "3",
                        "resourceName" : "Foo Test3"
                    }
                ]
            }
        ]
    }
    > 
    

    「$」位置演算子を使用して埋め込みドキュメントを更新するためのドキュメントは、「更新」ドキュメントにあります。 http://www.mongodb.org/display/DOCS/Updating#Updating-The%24positionaloperator

    「$push」修飾子のドキュメントは「更新」ページにもあります: http://www.mongodb.org/display/DOCS/Updating#Updating-%24push

    投稿されたコードからは、「リソース」がリストのように見えます。使用する必要のあるメソッドが$pushAllである可能性があり、リストに複数の値を追加するために使用されます: http://www.mongodb.org/display/DOCS/Updating#Updating-%24pushAll

    Javaドライバを使用すると、上記の挿入は次のように実行できます。

    Mongo m = new Mongo("localhost", 27017);
    DB db = m.getDB("test");
    DBCollection myColl = db.getCollection("myCollection");
    
    BasicDBObject docToInsert = new BasicDBObject("resourceID", "3");
    docToInsert.put("resourceName", "Foo Test3");
    
    BasicDBObject updateQuery = new BasicDBObject("_id", "1");
    updateQuery.put("itemList.itemID", "1");
    
    BasicDBObject updateCommand = new BasicDBObject("$push", new BasicDBObject("itemList.$.resources", docToInsert));
    
    myColl.update(updateQuery, updateCommand);
    System.out.println(myColl.findOne().toString());
    

    上記は以下を出力します:

    { "_class" : "com.model.Test" , "_id" : "1" , "itemList" : [ { "itemID" : "1" , "itemName" : "Foo" , "resources" : [ { "resourceID" : "1" , "resourceName" : "Foo Test1"} , { "resourceID" : "2" , "resourceName" : "Foo Test2"} , { "resourceID" : "3" , "resourceName" : "Foo Test3"}]}]}
    

    うまくいけば、上記のことで、Javaドライバーを使用して埋め込みドキュメントを更新することがMongoでどのように機能するかについての理解が深まるでしょう。この質問はSpringにも関連していることに気付きました(「mongoOperations」はSpringパッケージのクラスです)。残念ながら、私はよく知りません。それでもアップデートで問題が発生する場合は、Springに精通しているコミュニティの別のメンバーが支援できる可能性があります。




    1. NoSQLデータベースの戦い-MongoDBとFirebaseの比較

    2. MongoDB-配列要素を更新またはプッシュするための$set

    3. com.mongodb.client.MongoClientとcom.mongodb.MongoClientの違い

    4. Spring-Data-MongoDBを使用してエンティティに@TextIndex名を設定する方法