- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
给定一个包含以下文档的集合:
{
"_id": {
"$oid": "5e8f83289d3a48132e9b6e34"
},
"resource-id": "my-default-network-map",
"uri": "http://alto.example.com/networkmap",
"mappings": [
{
"version-tag": "X",
"address-aggregations": [{
"pid": "PID1",
"ipv4-addresses": ["192.0.2.0/24", "198.51.100.0/25"]
}, {
"pid": "PID2",
"ipv4-addresses": ["198.51.100.128/25"]
}, {
"pid": "PID3",
"ipv4-addresses": ["0.0.0.0/0"],
"ipv6-addresses": ["::/0"]
}]
},
{
"version-tag": "Y",
"address-aggregations": [{
"pid": "PID1",
"ipv4-addresses": ["192.0.2.0/24", "198.51.100.0/25"]
}, {
"pid": "PID2",
"ipv4-addresses": ["198.51.100.128/25"]
}]
}],
"_class": "com.example.restservice.entity.NetworkMapEntity"
}
并且假设更多这些文档与其他“resource-id”值一起存在,我希望返回我之前输入的相同文档,但“mappings”数组仅包含 version-tag = X 的对象和“address-aggregations”数组仅包含[pidx,pidy,...]中带有“pid”的对象。我目前能想到的最好的方法是以下聚合管道:
[
{
'$match': {
'resource-id': 'my-default-network-map'
}
}, {
'$unwind': {
'path': '$mappings'
}
}, {
'$match': {
'mappings.version-tag': 'X'
}
}, {
'$unwind': {
'path': '$mappings.address-aggregations'
}
}, {
'$match': {
'mappings.address-aggregations.pid': {
'$in': [
'PID1', 'PID2'
]
}
}
}, {
'$group': {
'_id': '$_id',
'resource-id': {
'$first': '$resource-id'
},
'uri': {
'$first': '$uri'
},
'version-tag': {
'$first': '$mappings.version-tag'
},
'address-aggregations': {
'$push': '$mappings.address-aggregations'
}
}
}, {
'$project': {
'_id': 1,
'resource-id': 1,
'uri': 1,
'mappings.version-tag': '$version-tag',
'mappings.address-aggregations': '$address-aggregations'
}
}, {
'$group': {
'_id': '$_id',
'resource-id': {
'$first': '$resource-id'
},
'uri': {
'$first': '$uri'
},
'mappings': {
'$push': '$mappings'
}
}
}
]
这在 mongodb 客户端 shell 上返回了预期结果。但是,当我将此类对象转换为带有聚合对象的 MongoTemplate 查询时:
Aggregation aggregation = newAggregation(
match(Criteria.where("resource-id").is(resourceId)),
unwind("mappings"),
match(Criteria.where("mappings.version-tag").is(versionTag)),
unwind("mappings.address-aggregations"),
match(Criteria.where("mappings.address-aggregations.pid").in(pids)),
group("$_id")
.first("resource-id").as("resource-id")
.first("uri").as("uri")
.first("mappings.version-tag").as("version-tag")
.push("mappings.address-aggregations").as("address-aggregations"),
project("_id", "resource-id", "uri")
.and("version-tag").as("mappings.version-tag")
.and("address-aggregations").as("mappings.address-aggregations"),
group("_id")
.first("resource-id").as("resource-id")
.first("uri").as("uri")
.push("mappings").as("mappings")
);
AggregationResults<NetworkMapEntity> aggregationResults = mongoTemplate.aggregate(aggregation, "NetworkMaps", NetworkMapEntity.class);
并测试它,抛出以下异常:java.lang.IllegalArgumentException:无效的引用'mappings'!
搜索周围我发现有类似问题的人说这是 springframework.data 依赖项的错误,但在一年前的版本上,所以我认为我对聚合对象的构造可能是问题所在。我在解决方案的 Java 代码部分做错了什么吗?
最佳答案
虽然我仍然不明白为什么当前的解决方案不起作用,并且想了解为什么不起作用,但我按如下方式更改了查询,现在它似乎按预期工作:
Aggregation aggregation = newAggregation(
match(Criteria.where("resource-id").is(resourceId)),
unwind("mappings"),
match(Criteria.where("mappings.version-tag").is(versionTag)),
unwind("mappings.address-aggregations"),
match(Criteria.where("mappings.address-aggregations.pid").in(pids)),
group("_id", "resource-id", "uri")
.first("mappings.version-tag").as("version-tag")
.push("mappings.address-aggregations").as("address-aggregations")
group("_id._id")
.first("_id.resource-id").as("resource-id")
.push(
new BasicDBObject("version-tag", "$version-tag")
.append("address-aggregations", "$address-aggregations")).as("mappings")
);
关于java - MongoTemplate聚合返回 "IllegalArgumentException: Invalid reference",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61190212/
我想在 java 中声明一个对象,就像在 C++ 中指向指针的指针,让我给你看一个例子: //*** At the application startup //Initialize a setting
考虑这段代码, struct A {}; struct B { B(const A&) {} }; void f(B) { cout << "f()"<
我正在尝试将一个C程序翻译成Rust。。C程序具有以下结构(归结为MRE):。在一个函数中,我将执行以下指针魔术:。不,我的问题是:我将如何在铁锈中实现同样的目标?。到目前为止,我在《铁锈》中尝试过的
我目前正在尝试将一个C程序翻译成Rust。。C程序具有以下结构(归结为MRE):。在一个函数中,我将执行以下指针魔术:。不,我的问题是:我将如何在铁锈中实现同样的目标?。到目前为止,我在《铁锈》中尝试
这个问题在这里已经有了答案: Add managed DLL dependencied to unmanaged C++ project (1 个回答) 关闭 6 年前。 我有这样一个场景: 使用
这是一个常见问答的集合,这也是一个社区维基,所以每个人都被邀请参与维护它。。正则表达式正在遭受给我ZE代码类型的问题和没有解释的糟糕答案。此参考旨在提供指向质量问答的链接。。此参考适用于以下语言:PH
我正在尝试在方案中模拟堆栈。我正在使用 DrScheme 并选择语言 R5RS。我需要创建 pop、push 和 peek 的函数。但我无法弄清楚如何通过引用传递。我已经阅读了一些关于盒子的信息,但是
我陷入了这个错误。我将代码部署在生产服务器上,它在端口 80 上运行。当我尝试登录管理页面时。如图所示,它给了我 403 错误。 可能是什么原因?我的 Django 代码或 nginx 配置有问题吗?
这是一段简单的 C++ 代码: A foo(){ A a; // create a local A object return a; } void bar(const A & a_r){ }
我正在使用从 torrenteditor 获取的 php 脚本来创建 torrent 文件,但是当我使用指定的方法创建新的 torrent 文件时,torrent 文件被创建但我收到很多通知。,就像这
MySQL: REFERENCES vs FOREIGN KEY + REFERENCES 我认为 REFERENCES 是更冗长的 FOREIGN KEY REFERENCES 语法的某种速记语法。
我想使用基于另一个方法引用的方法引用。这有点难以解释,所以我给你举个例子: Person.java public class Person{ Person sibling; int a
Java/C# 语言律师喜欢说他们的语言通过值传递引用。这意味着“引用”是在调用函数时复制的对象指针。 同时,在 C++ 中(以及在 Perl 和 PHP 中更动态的形式),引用是某个其他名称(或动态
当我需要实现递归 lambda 时,通常我这样做: auto factorial = [](auto& self, int n) -> int { return n == 0 ? 1 : n
我目前正在研究 DDD ,需要一些启发。 我有两个实体 Temple TempleVariant Temple(听筒)包含基本信息(名称,描述等),并具有n个变体,它们具有技术描述(CAD绘图,尺寸,
在 Grails 中 belongsTo允许一个域类与另一个域类建立级联关系。使用belongsTo时有两种类型的关系:引用和无引用。 Reference 在拥有的对象上创建属性,而 No Refer
我正在使用 AWS 和 Django Rest Framework 开发 Web 应用程序。(Django:v1.8,DRF:v3) 我一直在为 POST 多部分表单请求获取 django.reque
我按照下面的定义公开了 WCF 端点, 当我在 .NET 3.5 中添加“服务引用”时,我们在代理中获得了以下类,这非常好: [Syst
我在玩 constexpr 引用时产生了这种感觉。但问题本身与 constexpr 无关,只是被它揭示。 我们知道有“指向const的指针”,也有“const指针”。顺便说一句,由于后者的使用比前者少
我有 2 种类型的 refences,它们中的每一种都可以正常工作。 我尝试使用每一个并在 project build 中得到相同的结果。 请向我解释 COM 引用和引用之间的区别。 谢谢你。 最佳答
我是一名优秀的程序员,十分优秀!