首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >比较同一集合中的两个字段

比较同一集合中的两个字段
EN

Stack Overflow用户
提问于 2020-10-06 19:22:27
回答 1查看 149关注 0票数 1

我在Mongo有一个收藏。

我有两个字段:校验和和校验和N-4。

我已经做了一个这样的过滤器:

代码语言:javascript
复制
var filter = Builders<BsonDocument>.Filter.Eq("metadata.origin", sOrigin.ToString())
               & Builders<BsonDocument>.Filter.Eq("metadata.transfered", BsonNull.Value)
              & Builders<BsonDocument>.Filter.Eq("metadata.duplicate", BsonNull.Value)
             & Builders<BsonDocument>.Filter.Eq("metadata.malformed", BsonNull.Value);

我只想有一个文件,其中字段校验和和校验和N-4是不同的。

例如:

代码语言:javascript
复制
Cheksum : 2222222
checksumN-4 : 2222222

我想要这张唱片

代码语言:javascript
复制
Checksum : 8888888
ChecksumN-4 : 8889998

我不想要这张唱片

我如何在c#中做到这一点?

EN

回答 1

Stack Overflow用户

发布于 2020-10-06 20:34:29

您可以尝试使用如下表达式创建BsonDocumentFilterDefinition

代码语言:javascript
复制
 var builder = Builders<BsonDocument>.Filter;
 var filter = builder.Eq("metadata.origin", sOrigin.ToString())
              & builder.Eq("metadata.transfered", BsonNull.Value)
              & builder.Eq("metadata.duplicate", BsonNull.Value)
              & builder.Eq("metadata.malformed", BsonNull.Value)
              & new BsonDocumentFilterDefinition<BsonDocument>(new BsonDocument(
                    "$expr", new BsonDocument(
                        "$eq", new BsonArray
                        {
                            "$checksumN-4", "$checksum"
                        })));
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/64224766

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档