- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
在这种情况下,我有两个模型:协议(protocol)和评论。每个模型都有一个调用另一个模型的中间件('pre' 或 'remove')。在 Comment.js 中调用 Comment 中间件会在 Protocol.findById() 处停止,因为 Protocol 是一个对象而不是模型函数。这是 Comment.js 中的 console.log(Protocol)
Protocol : [object Object] Type : object
当 const Comment = require('../models/comment')
在 Protocol.js 中被移除时,Comment.js 中间件工作,控制台将其中的 Protocol 视为关注:
Protocol : function model(doc, fields, skipId) {
model.hooks.execPreSync('createModel', doc);
if (!(this instanceof model)) {
return new model(doc, fields, skipId);
}
Model.call(this, doc, fields, skipId);
} Type : function
我不明白这种行为。此外,反过来,Protocol.js 中间件工作正常,尽管 Comment.js 有 const Protocol = require('../models/protocol')
我在 another topic 中发现了一个技巧,也就是把中间件Protocol.findById()
里面替换成mongoose.model('Protocol').findById()
,但这并不能说明问题。
脚本如下所示。如果您需要更多信息,请告诉我,我会提供。谢谢
Protocol.js 模型和中间件
// Dependencies
const mongoose = require('mongoose')
//Models
//<!---- If Comment is not required here then the Comment Middleware works ---->!
const Comment = require('../models/comment')
//Schema
const protocolSchema = mongoose.Schema({
_id : mongoose.Schema.Types.ObjectId,
title: {
type : String,
required: true
},
comments : [{
type: mongoose.Schema.Types.ObjectId,
ref : 'Comment',
}]
})
//Middleware Hook Call
protocolSchema.pre('remove', async function() {
console.log('Starts Protocol.schema.pre(\'remove\')')
var toBeDeletedProtocol = this
await removeComments()
function removeComments(){
return new Promise ((resolve, reject) => {
console.log('Starts removeComments()')
var deletedComments = []
Comment.find({protocol : toBeDeletedProtocol._id})
.exec()
.then( comments => {
console.log('comments found: ' + comments)
return resolve()
})
.catch(err => {
console.log('Removing comment(s) related to the deleted protocol failed in protocol remove Hook')
return reject(err)
})
})
}
})
//Model Export
module.exports = mongoose.model('Protocol', protocolSchema)
Comment.js 模型和中间件
//Dependencies
const mongoose = require('mongoose')
//Models
const Protocol = require('../models/protocol')
//Schema
const commentSchema = mongoose.Schema(
{
_id : mongoose.Schema.Types.ObjectId,
content: {
type: String,
required : true
},
protocol : {
type: mongoose.Schema.Types.ObjectId,
ref : 'Protocol',
required : true,
}
}
)
//Middleware Hook Call
commentSchema.pre('save', async function() {
console.log('Starts Comment.schema.pre(\'save\')')
var toBeSavedComment = this
await updateProtocol()
function updateProtocol(){
return new Promise ((resolve, reject) => {
console.log('Starts updateProtocol()')
console.log('toBeSavedComment : '+ toBeSavedComment)
console.log('Protocol : '+ Protocol, 'Type : ' + typeof Protocol)
//<!----- the ERROR occurs here -----!>
Protocol.findById(toBeSavedComment.protocol)
//<!----- Protocol is seen an object instead of a model function -----!>
.exec()
.then( protocol => {
console.log('protocol found : ' + protocol)
return resolve()
})
.catch(err => {
console.log('Error in updateProtocol() in Comment.schema pre \'save\'')
console.log(err)
return reject(err)
})
})
}
})
//Export
module.exports = mongoose.model('Comment', commentSchema
)
Package.json
{
"name": "debug",
"version": "1.0.0",
"description": "",
"main": "app.js",
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1",
"start": "node server.js"
},
"author": "",
"license": "ISC",
"dependencies": {
"body-parser": "^1.18.3",
"express": "^4.16.4",
"mongoose": "^5.3.2",
"nodemon": "^1.18.4"
}
}
最佳答案
已经有一段时间了,到目前为止我还没有遇到同样的问题,所以我仍然没有明确的解决方案。但我现在看到一个可能导致这种无法解释的行为的错误。我在 console.log 中连接变量或对象,例如:
console.log('toBeSavedComment : '+ toBeSavedComment)
console.log('Protocol : '+ Protocol, 'Type : ' + typeof Protocol)
请改用逗号“,”:
console.log('toBeSavedComment : ', toBeSavedComment)
console.log('Protocol : ', Protocol, 'Type : ' , typeof Protocol)
console.log 中的对象串联,例如,在 Amazone Web Service 中:Elastic Beanstalk 阻止 API 编译。
这不是真正的答案,但我希望这可能有所帮助!
关于node.js - 由于外部模型, Hook (预中间件)中的 Mongoose 模型查询(findById)错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52876293/
当我保存4条记录时,我需要将它们一一保存,所以我的代码是 a.save(function(){ b.save(function(){ c.save(function(){ d.save(f
Mongoose在版本4.2.7中创建了一个新的单个子文档功能(documentation和feature request),允许使用单个嵌入式子文档架构,其行为方式与一对多子文档的行为相同。 在父级
Mongoose 版本 >= 4.0 有一个时间戳选项,当 timestamps 设置为 时,该选项会为架构创建 updatedAt 和 createdAt 字段正确。 http://mongoose
我注意到某些图书馆喜欢 mock 鹅 ( https://github.com/mccormicka/Mockgoose/blob/master/test/index.spec.js ) 使用 req
我正在与 Mongoose 合作。我见过很多开发者发出以下命令: mongoose.Promise = global.Promise; 然后我很好奇 mongoose.Promise 的原始值是什么。
当我运行与数据库大量连接和断开连接的测试时,我收到以下警告。 (node) warning: possible EventEmitter memory leak detected. 11 connec
我可以在 Mongoose 的子文档数组中填充动态引用(使用“refPath”)虚拟字段吗? 数据结构如下 Group - Members -> User 代码:模型/模式 let MemberSc
我正在我的应用程序中做一些测试,看看内存缓存是否真的在工作。但是,由于 memory-cache 显然没有公开“命中”事件,我无法判断是否真的从缓存中获取数据。所以我试着看看当应用程序实际从数据库中获
我是 nestjs 的新手。我使用 @nestjs/mongoose,我需要在我的类模式中引用嵌套对象中的几个字段,但我不知道该怎么做。 dietDays 对象必须包含一个日期字段和包含对 Meal
我是 mongodb 的新手,我有一个这样的数据模型 { last_updated: Date.now(), csgo_items:[ {name: 'name', p
这是我的方案: var documentSchema = mongoose.Schema({ 'facts': [{ 'type': { type: String, requi
我想删除多个 _ids = ['123', '234', '345']; _ids.forEach(_id => { await model.deleteOne({ _id }); }); 有没有
我有一个像这样的 Mongoose 模式: var Address = { doorNo:String, city:String, state:String, coun
我的文档包含一个名为 clients 的字段那应该包含一组客户端ID。 { "first_name":"Nick", "last_name":"Parsons", "email":"nic
我遇到了以下我无法理解的代码行,尽管有很多教程提供了与 populate 的示例相关的信息。但没有一个能解释它究竟意味着什么。这是一个例子 var mongoose = require('mongoo
我有一个具有多个唯一性的架构,如下所示: var userSchema = new mongoose.Schema({ user: { type: String, unique:
我有一个 Mongoose 模式,其中有 4 个子模式。我一直在关注这里的文档https://github.com/LearnBoost/mongoose关于嵌入文档 var scenarios =
我希望每个字符串属性都默认设置为 true。有办法吗? ?? mongoose.Schema.String -> default { trim: true } var schema = new Sch
我有这个代码 var ClientSchema = new Schema({ name: {type: String, required: true, trim: true} }); var Cl
许多教程告诉您在您的 userSchema 页面中使用 bycrypt。保存新用户后,它会附带加密密码。伟大的。然而,我想,当我用某些东西编辑用户时,它也会重新哈希密码,导致无法登录。你能给我一个解决
我是一名优秀的程序员,十分优秀!