2.6 KiB
2.6 KiB
id, title, challengeType, forumTopicId, localeTitle
id | title | challengeType | forumTopicId | localeTitle |
---|---|---|---|---|
587d7fb8367417b2b2512c0e | Perform Classic Updates by Running Find, Edit, then Save | 2 | 301541 | 通过执行查找、编辑、保存来执行更新 |
Description
在传统的应用中,如果想要编辑 document 并在其它地方使用它(比如放到服务器的返回数据中),就必须执行查找、编辑和保存。Mongoose 有一个专用的更新方法 Model.update()
,它与底层的 mongo 驱动绑定。通过这个方法,我们可以批量编辑符合特定条件的多个 document。但问题在于,这个方法不会返回更新后的 document,而是返回状态信息。此外,由于它是直接调用 mongo 的底层驱动,因此它让处理 model 的验证变得更加棘手。
Instructions
personId
作为字段,在数据库中通过 _id
找到相应的 person(你可以使用之前挑战中的任何一种方法)。然后,将 "hamburger" 添加到它的 favoriteFoods
中(你可以使用 Array.push()
)。之后,在 .find()
的回调里通过 .save()
方法更新数据库。
提示:如果你在 Schema 中将 favoriteFoods
声明为一个 Array(数组)并且没有指定数组的类型(如 [String]
),那么此时,favoriteFoods
就会是默认的 Mixed 类型。如果想编辑它,就必须执行 document.markModified('edited-field')
。请参阅 Mongoose 文档
Tests
tests:
- text: 应成功地对一条数据进行查找、编辑和更新
testString: "getUserInput => $.post(getUserInput('url') + '/_api/find-edit-save', {name:'Poldo', age: 40, favoriteFoods:['spaghetti']}).then(data => { assert.equal(data.name, 'Poldo', 'item.name is not what is expected'); assert.equal(data.age, 40, 'item.age is not what expected'); assert.deepEqual(data.favoriteFoods, ['spaghetti', 'hamburger'], 'item.favoriteFoods is not what expected'); assert.equal(data.__v, 1, 'The item should be previously edited'); }, xhr => { throw new Error(xhr.responseText); })"
Challenge Seed
Solution
/**
Backend challenges don't need solutions,
because they would need to be tested against a full working project.
Please check our contributing guidelines to learn more.
*/