- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我需要创建具有特定条件的子文档数组。如果 ip
agent
和 language
字段都完全匹配,那么就不需要添加新的子文档,如果其中任何一个下降,那么我需要创建一个新的。
但是当我尝试使用 $push
执行此操作时,它会返回我
Exception: StrictModeError: Path "ip" is not in schema, strict mode is `true`, and upsert is `true`.
findOneAndUpdate
更新整个文档和我的字段集,因为它们出现在数据库中。还尝试按照模式中显示的方式设置它,但它返回相同的错误。
userSchema中的数组
metadata: [mongoose.modelSchemas.UserMetaData],
用户元数据架构
var userMetaDataSchema = new mongoose.Schema({
ip: { type: String, default: '' },
agent: { type: String, default: '' },
language: { type: String, default: '' },
userCreated: {
id: { type: mongoose.Schema.Types.ObjectId, ref: 'User' },
name: { type: String, default: '' },
}
});
app.db.model('UserMetaData', userMetaDataSchema);
};
如果我尝试直接使用 findOneAndUpdate
到 UserMetaData
集合而不使用 $push
,它会起作用。
控制台的结果:
{
"_id" : ObjectId("5a00d35f03fc3eb63cbb1c6f"),
"agent" : "Mozilla/5.0 (Windows NT 6.3; Win64; x64; rv:56.0) Gecko/20100101 Firefox/56.0",
"ip" : "::ffff:192.168.33.10",
"language" : "en-US,en;q=0.5",
"userCreated" : {
"name" : "user2",
"id" : ObjectId("5a00d27a7fdf8e07f40d2123")
},
"__v" : 0
}
查询不起作用
var fieldsToSet = {
$push: {
metadata: {
agent: userAgent,
ip: userIp,
language: languages,
userCreated: {
name: req.user.username,
id: req.user._id,
}
}
}
};
var options = { upsert: true };
User.findOneAndUpdate(conditions, fieldsToSet, options, function(err, user) {....
创建此类数组的最佳方法是什么?谢谢。
最佳答案
这里的错误是由于尝试将 findOneAndUpdate
与 $push
和 {upsert: true}
选项一起使用而引起的,因为如果您想要插入或更新子文档,您应该使用 2 个不同的运算符 $set
进行更新,使用 $push
进行插入。所以这里的解决方案是使用不同的设置进行更新和插入:
var conditions = {
_id: req.user._id,
'metadata.ip': userIp,
'metadata.agent': userAgent,
'metadata.language': userLanguage,
'metadata.userCreated.name': req.user.username
};
var fieldsToSet = {
$set: {
'metadata.$.agent': userAgent,
'metadata.$.ip': userIp,
'metadata.$.language': userLanguage,
}
};
var fieldsToPush = {
$push: {
metadata: {
agent: userAgent,
ip: userIp,
language: userLanguage,
userCreated: {
id: req.user._id,
name: req.user.username,
}
}
}
};
var options = { upsert: true };
// check if thare is a match and overwright
User.findOneAndUpdate(conditions, fieldsToSet, options, function (err, setdocs) {
//if there is no match then push a new subdocument
if (setdocs == null) {
User.findByIdAndUpdate(req.user._id, fieldsToPush, function (err, pushdocs) {
//...
});
}
else {
//....
}
});
});
此解决方案归功于 Neil Lunn我现在找不到这个特定的解决方案
关于node.js - Mongoose - 使用 findoneandupdate 和 $push 添加或更新子文档(当 upsert 为 true 时),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47148415/
当我保存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。保存新用户后,它会附带加密密码。伟大的。然而,我想,当我用某些东西编辑用户时,它也会重新哈希密码,导致无法登录。你能给我一个解决
我是一名优秀的程序员,十分优秀!