javascript - mongoose保存报错
问题描述
// 我在用户Schema中创建了专栏数组(articles),专栏是对象,底下articles数组嵌套了文章对象,结构类似下图:// User.articles = [专栏一, 专栏二 ...]// 专栏一.articles = [ 文章一, 文章二 ...]// 实际操作中,只要涉及到修改原有值,一保存就报错// 如splice,pop,或者直接赋值都报错,但push就成功// 找到专栏,对专栏文章进行splice可以成功修改,但保存操作时报错user.articles[cindex].articles.splice(aindex, 1, newarticle) // cindex 专栏序号 aindex 文章序号id = column.articles[aindex]._idconsole.log('发布文章更新,id为:', id) // 能输出结果user.save()// 可成功修改,保存报错user.articles[cindex].articles[aindex].name = ’asdfsadf’user.save()// 成功column.articles.push({ _id : column.articles[aindex]._id, name: ’asdfsdf’})user.save()// 报错如下:// Unhandled rejection Error// at model.wrappedPointCut [as save] (C:nodejsmyblognode_modulesmongooselibservicesmodelapplyHooks.js:111:29)// at User.findOne.then.user (C:nodejsmyblogmodelsUserActions.js:299:10)// at tryCatcher (C:nodejsmyblognode_modulesbluebirdjsreleaseutil.js:16:23)// at Promise._settlePromiseFromHandler (C:nodejsmyblognode_modulesbluebirdjsreleasepromise.js:512:31)// at Promise._settlePromise (C:nodejsmyblognode_modulesbluebirdjsreleasepromise.js:569:18)// at Promise._settlePromise0 (C:nodejsmyblognode_modulesbluebirdjsreleasepromise.js:614:10)// at Promise._settlePromises (C:nodejsmyblognode_modulesbluebirdjsreleasepromise.js:693:18)
当我使用 save(err=>console.log(err)) 时,报错versionkey错误,之后我禁用掉versionkey便暂时防止了这个错误的产生。但终究还是没有弄清楚这个问题的来由。还请各位大大详解。
问题解答
回答1:对数据库数据修改和保存都需要使用相关方法才行,不能说直接操作数据属性,完了用save
回答2:save方法有参数
相关文章:
1. mysql - 数据库建字段,默认值空和empty string有什么区别 1102. sql语句 - 如何在mysql中批量添加用户?3. mysql建表报错,查手册看不懂,求解?4. PHP类属性声明?5. 求大神支招,php怎么操作在一个html文件的<head>标记内添加内容?6. 怎么php怎么通过数组显示sql查询结果呢,查询结果有多条,如图。7. 致命错误: Class ’appfacadeTest’ not found8. 老师们php,插入数据库mysql,都是空的,要怎么解决9. javascript - mysql插入数据时怎样避免与库中的数据重复?10. phpstady在win10上运行
