У меня возникла эта проблема при фильтрации документов в mongodb после выполнения поиска в C #.Я использую несколько поисков, и мне нужно отфильтровать документы из последней дочерней коллекции.Ниже приведен список коллекции:
Коллекция 1: Id, ParentId, Desc, Index
Идентификатор коллекции 2, ParentId, Desc, Index, Coll2Desc1, Coll2Desc2
Идентификатор коллекции 3,ParentId, Desc, Index, Coll3Desc1, Coll3Desc2
Collection 4 Id, ParentId, Desc, Index, Coll4Desc1, Coll4Desc2
Теперь мне нужно отфильтровать и получить только те записи, для которых Coll4Desc1 не равен NULL илипустой.Я попытался добавить $ match после кода проекции, он не работает.Если бы кто-нибудь мог помочь мне отфильтровать необходимые документы, это было бы здорово.
Ниже приведен код агрегации поиска, который я написал:
var collectionList = list.OrderBy(x => x.CollectionOrder).Select(x => x.CollectionName).Distinct().ToList();
// Load data into deviations
var listOfDocuments = new List<BsonDocument>();
var firstCollection = dbContext.GetCollection(collectionList[0]);
var options = new AggregateOptions()
{
AllowDiskUse = false
};
var previousCollectionName = "";
var sortProject = new BsonDocument();
var groupBy = new List<BsonDocument>();
for (int i = 0; i < collectionList.Count - 1; i++)
{
var collectionName = collectionList[i];
IMongoCollection<BsonDocument> collection = dbContext.GetCollection(collectionName);
if (i == 0)
{
firstCollection = collection;
var firstarray = new BsonDocument("$project", new BsonDocument()
.Add("_id", 0)
.Add(collectionName, "$$ROOT"));
listOfDocuments.Add(firstarray);
}
else
{
// join all the collections
var remainingArray = new BsonDocument("$lookup", new BsonDocument()
.Add("localField", previousCollectionName + "." + "Id")
.Add("from", collectionName)
.Add("foreignField", "ParentId")
.Add("as", collectionName));
listOfDocuments.Add(remainingArray);
remainingArray = new BsonDocument("$unwind", new BsonDocument()
.Add("path", "$" + collectionName)
.Add("preserveNullAndEmptyArrays", new BsonBoolean(true)));
listOfDocuments.Add(remainingArray);
sortProject.Add(previousCollectionName + "." + "Id", 1);
}
previousCollectionName = collectionName;
}
// Project the columns
var columnList = list.OrderBy(x => x.ColumnOrder).Where(x => x.IsVisible == true).ToList();
var docProjection = new BsonDocument();
for (int i = 0; i < columnList.Count; i++)
{
docProjection.Add(columnList[i].ColumnName, "$" + columnList[i].CollectionName + "." + columnList[i].FieldName);
}
listOfDocuments.Add(new BsonDocument("$project", docProjection));
listOfDocuments.Add(new BsonDocument("$sort", sortProject));
var match2 = new BsonDocument
{
{
"$match",
new BsonDocument
{
{"Collection4.Coll4Desc1", new BsonDocument
{
{
"$ne", ""
}
}
}
}
}
};
listOfDocuments.Add(match2);
PipelineDefinition<BsonDocument, BsonDocument> pipeline = listOfDocuments;
var listOfDocs = new List<BsonDocument>();
firstCollection.AggregateAsync(pipeline, options))
using (var cursor = firstCollection.Aggregate(pipeline, options))
{
while (cursor.MoveNext())
{
var batch = cursor.Current;
foreach (BsonDocument document in batch)
{
listOfDocs.Add(document);
}
}
}