- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我无法理解 Mongoose 的种群逻辑。
我有一个 UserSchema,其中包含一系列文章。
articles: {
type: [{
article: {
type: Schema.Types.ObjectId,
ref: "Article"
},
read: Boolean,
starred: Boolean
}]
},
文章存储在单独的集合中。现在我想找到用户的所有加星标的文章,填充这些文章,按发布日期对它们进行排序并对结果进行分页。
User.findOne({_id: user.id, "articles.starred": true}).populate({path: "articles.article", options: {sort: {"published": -1}, skip: 20, limit: 20}}).exec(function(err, _user) {
callback(_user);
});
问题是,人口已经完成,但选项却被完全忽略了。
这是用户和文章的样子:
用户:
{
"__v" : 0,
"_id" : ObjectId("5284ef45fe46a55194000003"),
"articles" : [
{
"article" : ObjectId("5284ef52fe46a55194000005"),
"read" : true,
"starred" : true,
"_id" : ObjectId("5284ef53fe46a55194000ae1")
}
],
"categories" : [
{
"_id" : ObjectId("5284ef52fe46a55194000004"),
"feeds" : [
{
"url" : "http://feeds.dzone.com/zones/dotnet",
"name" : ".NET Zone - Community for .NET developers everywhere"
}
],
"name" : ".NET"
}
],
"email" : "xxxx",
"google" : {},
"name" : "xxxx",
"provider" : "xxxx"
}
文章:
{
"author" : "Michael Hession",
"title" : "You'll Never Want to Put Away This Elegant Pour-Over Coffee Dripper",
"published" : ISODate("2013-06-13T16:38:00.000Z"),
"link" : "http://gizmodo.com/youll-never-want-to-put-away-this-elegant-pour-over-co-513136433",
"feed" : {
"title" : "Gizmodo",
"link" : {
"html" : "http://gizmodo.com",
"xml" : "feed/http://feeds.gawker.com/gizmodo/excerpts.xml"
}
},
"summary" : "html content",
"_id" : ObjectId("5284ef52fe46a55194000005"),
"__v" : 0
}
最佳答案
由于我还找不到解决方案,所以我采取了解决方法。
User.findOne({_id: user.id, "articles.starred": false}).populate({path: "articles.article"}).exec(function(err, _user) {
if (!err && _user) {
var articles = _user.articles.sort(function(art1, art2) {
d1 = art1.article.published;
d2 = art2.article.published;
if (d1 > d2) return -1;
if (d1 < d2) return 1;
return 0;
}).slice(skip, skip + 20);
callback(articles);
} else {
callback([]);
};
});
如果有人提出更好的主意,请告诉我。
经过大量研究后,我更改了 UserSchema 并找到了一个更好的解决方案,它使用了 mongoose API 文档中解释的人口。
var UserSchema = new Schema({
name: {
type: String,
default: ""
},
email: {
type: String,
default: ""
},
provider: {
type: String,
default: ""
},
categories: {
type: [Category]
},
articles: {
read: [{type: Schema.Types.ObjectId, ref: "Article"}],
unread: [{type: Schema.Types.ObjectId, ref: "Article"}],
starred: [{type: Schema.Types.ObjectId, ref: "Article"}]
},
google: {},
facebook: {},
twitter: {}
});
User.findById(user.id, "articles." + params.state, function(err, _user) {
User.populate(_user, {path: "articles." + params.state, options: {sort: {"published": -1}, skip: params.skip, limit: 20}}, function(_err, __user) {
if (!_err && __user) {
callback(__user.articles[params.state]);
} else {
callback([]);
};
});
});
关于node.js - Mongoose 种群忽略选项,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19983532/
当我保存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。保存新用户后,它会附带加密密码。伟大的。然而,我想,当我用某些东西编辑用户时,它也会重新哈希密码,导致无法登录。你能给我一个解决
我是一名优秀的程序员,十分优秀!