我在这里学习MongoDB。我坚持使用MyGoDB Java驱动程序执行一个非常基本的操作。我正试图从文档中的数组中删除一个元素。文档如下所示:

db.test.find().pretty()
{
    "_id" : ObjectId("581245dd51030d389f5cf701"),
    "name" : "Rahul",
    "scores" : [
        {
            "SDM" : 97
        },
        {
            "SE" : 96
        },
        {
            "DM" : 80
        }
    ]
}

我正试图删除数组中的第二个元素,即{"SE" : 96}。我知道我可以使用coll.update(match, new BasicDBObject("$pull", update));实现这一点。不过,我想利用com.mongodb.client.model.Updates.pull(final String fieldName, final TItem value)方法。
这是我在发布问题之前尝试过的:
1)当我试着这样做时,我希望什么也不会发生,事实上,文件没有修改。
  ` Bson filter = Filters.eq("name", "Rahul");
    Bson delete = Updates.pull("SE", 96);
    collection.updateOne(filter, delete);`

2)以下操作引发异常。
  ` Bson filter = Filters.eq("name", "Rahul");
    Bson delete = Updates.pull("scores.SE", 96);
    collection.updateOne(filter, delete);`

例外情况:
Exception in thread "main" com.mongodb.MongoWriteException: cannot use the part (scores of scores.SE) to traverse the element ({scores: [ { SDM: 97.0 }, { SE: 96.0 }, { DM: 80.0 } ]})
    at com.mongodb.MongoCollectionImpl.executeSingleWriteRequest(MongoCollectionImpl.java:523)
    at com.mongodb.MongoCollectionImpl.update(MongoCollectionImpl.java:508)
    at com.mongodb.MongoCollectionImpl.updateOne(MongoCollectionImpl.java:355)
    at com.mongodb.MongoCollectionImpl.updateOne(MongoCollectionImpl.java:350)
    at com.mongodb.mongoProject.crud.UpdateTest.main(HW_3_1.java:30)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:497)
    at com.intellij.rt.execution.application.AppMain.main(AppMain.java:144)

请让我知道我做错了什么。
谢谢。。。

最佳答案

试试这个:
Bson delete = Updates.pull("scores", new Document("SE", 96));

关于arrays - MongoDB:使用Java驱动程序,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/40292201/

10-11 22:25
查看更多