- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
有一个User的集合
{ "_id" : ObjectId("5a0d45ca8af3a91847b7cf95"), "updatedAt" : ISODate("2017-11-16T09:34:14.651Z"), "createdAt" : ISODate("2017-11-16T08:01:14.119Z"), "name" : "John", "email" : "test1@gmail.com", "groupsFavorite" : [ ObjectId("5a0d45db8af3a91847b7cf96") ], "groups" : [ ObjectId("5a0d45db8af3a91847b7cf96"), ObjectId("5a0d45e18af3a91847b7cf97") ], "__v" : 3}
有一组集合
/* 1 */{ "_id" : ObjectId("5a0d45db8af3a91847b7cf96"), "updatedAt" : ISODate("2017-11-16T08:01:31.815Z"), "createdAt" : ISODate("2017-11-16T08:01:31.815Z"), "userId" : ObjectId("5a0d45ca8af3a91847b7cf95"), "title" : "New title", "slug" : "new-title-1", "description" : "Lorem", "__v" : 0}/* 2 */{ "_id" : ObjectId("5a0d45e18af3a91847b7cf97"), "updatedAt" : ISODate("2017-11-16T08:01:37.005Z"), "createdAt" : ISODate("2017-11-16T08:01:37.005Z"), "userId" : ObjectId("5a0d45ca8af3a91847b7cf95"), "title" : "New title", "slug" : "new-title-2", "description" : "Lorem", "__v" : 0}/* 3 */{ "_id" : ObjectId("5a0d5cb0cd59342da943d55a"), "updatedAt" : ISODate("2017-11-16T09:38:56.912Z"), "createdAt" : ISODate("2017-11-16T09:38:56.912Z"), "userId" : ObjectId("5a0d5c48cd59342da943d559"), "title" : "New title", "slug" : "new-title-3", "description" : "Lorem", "__v" : 0}
有一种方法可以返回特定用户的组。有必要将这些数据添加到favorite: true
或false
的新属性中以建表。
例如:
{ "_id" :"5a0d45db8af3a91847b7cf96", "updatedAt" : "2017-11-16T08:01:31.815Z", "createdAt" : "2017-11-16T08:01:31.815Z", "userId" : "5a0d45ca8af3a91847b7cf95", "title" : "New title", "slug" : "new-title-1", "description" : "Lorem", "favorite": "true"},{ "_id" : "5a0d45e18af3a91847b7cf97", "updatedAt" : "2017-11-16T08:01:37.005Z", "createdAt" : "2017-11-16T08:01:37.005Z", "userId" : "5a0d45ca8af3a91847b7cf95", "title" : "New title", "slug" : "new-title-2", "description" : "Lorem", "favorite": "false"},{ "_id" : "5a0d5cb0cd59342da943d55a", "updatedAt" : "2017-11-16T09:38:56.912Z", "createdAt" : "2017-11-16T09:38:56.912Z", "userId" : "5a0d5c48cd59342da943d559", "title" : "New title", "slug" : "new-title-3", "description" : "Lorem", "favorite": "false"}
最佳答案
您可以使用 $lookup
运算符来检查“用户”集合中的 _id
和 userId
字段。并且为了确定它是否存在,您可以使用 $eq
运算符。
db.getCollection('Groups').aggregate([
{
$lookup:
{
from: "User",
localField: "_id",
foreignField: "groupsFavorite",
as: "FavoriteByGrp"
}
}
,{
$lookup:
{
from: "User",
localField: "userId",
foreignField: "_id",
as: "FavoriteByUsr"
}
}
,{
"$project":
{
_id:1,
updatedAt:1,
createdAt:1,
userId:1,
title:1,
slug:1,
description:1,
favorite:
{
"$cond":
{
if: { "$eq": [ "$FavoriteByGrp._id", "$FavoriteByUsr._id" ] },
then: "true",
else: "false"
}
}
}
}
])
结果:
/* 1 */
{
"_id" : ObjectId("5a0d45db8af3a91847b7cf96"),
"updatedAt" : ISODate("2017-11-16T08:01:31.815Z"),
"createdAt" : ISODate("2017-11-16T08:01:31.815Z"),
"userId" : ObjectId("5a0d45ca8af3a91847b7cf95"),
"title" : "New title",
"slug" : "new-title-1",
"description" : "Lorem",
"favorite" : "true"
}
/* 2 */
{
"_id" : ObjectId("5a0d45e18af3a91847b7cf97"),
"updatedAt" : ISODate("2017-11-16T08:01:37.005Z"),
"createdAt" : ISODate("2017-11-16T08:01:37.005Z"),
"userId" : ObjectId("5a0d45ca8af3a91847b7cf95"),
"title" : "New title",
"slug" : "new-title-2",
"description" : "Lorem",
"favorite" : "false"
}
/* 3 */
{
"_id" : ObjectId("5a0d5cb0cd59342da943d55a"),
"updatedAt" : ISODate("2017-11-16T09:38:56.912Z"),
"createdAt" : ISODate("2017-11-16T09:38:56.912Z"),
"userId" : ObjectId("5a0d5c48cd59342da943d559"),
"title" : "New title",
"slug" : "new-title-3",
"description" : "Lorem",
"favorite" : "false"
}
关于mongodb - 向输出 json 添加其他属性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47330806/
你能比较一下属性吗 我想禁用文本框“txtName”。有两种方式 使用javascript,txtName.disabled = true 使用 ASP.NET, 哪种方法更好,为什么? 最佳答案 我
Count 属性 返回一个集合或 Dictionary 对象包含的项目数。只读。 object.Count object 可以是“应用于”列表中列出的任何集合或对
CompareMode 属性 设置并返回在 Dictionary 对象中比较字符串关键字的比较模式。 object.CompareMode[ = compare] 参数
Column 属性 只读属性,返回 TextStream 文件中当前字符位置的列号。 object.Column object 通常是 TextStream 对象的名称。
AvailableSpace 属性 返回指定的驱动器或网络共享对于用户的可用空间大小。 object.AvailableSpace object 应为 Drive 
Attributes 属性 设置或返回文件或文件夹的属性。可读写或只读(与属性有关)。 object.Attributes [= newattributes] 参数 object
AtEndOfStream 属性 如果文件指针位于 TextStream 文件末,则返回 True;否则如果不为只读则返回 False。 object.A
AtEndOfLine 属性 TextStream 文件中,如果文件指针指向行末标记,就返回 True;否则如果不是只读则返回 False。 object.AtEn
RootFolder 属性 返回一个 Folder 对象,表示指定驱动器的根文件夹。只读。 object.RootFolder object 应为 Dr
Path 属性 返回指定文件、文件夹或驱动器的路径。 object.Path object 应为 File、Folder 或 Drive 对象的名称。 说明 对于驱动器,路径不包含根目录。
ParentFolder 属性 返回指定文件或文件夹的父文件夹。只读。 object.ParentFolder object 应为 File 或 Folder 对象的名称。 说明 以下代码
Name 属性 设置或返回指定的文件或文件夹的名称。可读写。 object.Name [= newname] 参数 object 必选项。应为 File 或&
Line 属性 只读属性,返回 TextStream 文件中的当前行号。 object.Line object 通常是 TextStream 对象的名称。 说明 文件刚
Key 属性 在 Dictionary 对象中设置 key。 object.Key(key) = newkey 参数 object 必选项。通常是 Dictionary 
Item 属性 设置或返回 Dictionary 对象中指定的 key 对应的 item,或返回集合中基于指定的 key 的&
IsRootFolder 属性 如果指定的文件夹是根文件夹,返回 True;否则返回 False。 object.IsRootFolder object 应为&n
IsReady 属性 如果指定的驱动器就绪,返回 True;否则返回 False。 object.IsReady object 应为 Drive&nbs
FreeSpace 属性 返回指定的驱动器或网络共享对于用户的可用空间大小。只读。 object.FreeSpace object 应为 Drive 对象的名称。
FileSystem 属性 返回指定的驱动器使用的文件系统的类型。 object.FileSystem object 应为 Drive 对象的名称。 说明 可
Files 属性 返回由指定文件夹中所有 File 对象(包括隐藏文件和系统文件)组成的 Files 集合。 object.Files object&n
我是一名优秀的程序员,十分优秀!