MongoTemplate pull subdocument

fer*_*spr 10 mongodb mongodb-query mongotemplate

我需要在MongoTemplate中拉一个子文档,但无法弄清楚如何做到这一点.

我保存的文件是:

{
    "_id" : "FooUser",
    "_class" : "com.domain.User",
    "tests" : [ 
        {
            "variant" : {
                "_id" : "C",
                "probability" : "0.5"
            },
            "experiment" : {
                "$ref" : "experiment",
                "$id" : "MyExperiment2"
            }
        }, 
        {
            "variant" : {
                "_id" : "B",
                "probability" : "0.5"
            },
            "experiment" : {
                "$ref" : "experiment",
                "$id" : "MyExperiment1"
            }
        }
    ]
}
Run Code Online (Sandbox Code Playgroud)

我只需要删除具有MyExperiment1的测试.执行以下命令有效:

db.user.update( {}, {$pull: { "tests":{"experiment.$id":"MyExperiment1"}}}, {multi: true} )
Run Code Online (Sandbox Code Playgroud)

我应该如何使用Spring MongoTemplate编写这个?

我尝试了以下,但不起作用:

this.mongoTemplate.updateMulti(new Query(), new Update().pull("tests", "{\"experiment.$id\":\"MyExperiment1\"}"), "user");
Run Code Online (Sandbox Code Playgroud)

谢谢.

fer*_*spr 12

看来这很有效:

this.mongoTemplate.updateMulti(new Query(),
        new Update().pull("tests", Query.query(Criteria.where("experiment.$id").is("MyExperiment1"))), USERS_COLLECTION_NAME);
Run Code Online (Sandbox Code Playgroud)

  • cid="idvalue" this.mongoTemplate.updateMulti(new Query(), new Update().pull("tests", Query.query(Criteria.where("experiment.$id").is(cid))), USERS_COLLECTION_NAME); 它是匹配结果但不删除元素。如何在拉取操作中匹配字符串id值ObjectId。 (2认同)