MongoDB Поиск и фильтр в C # - PullRequest
0 голосов
/ 15 ноября 2018

У меня возникла эта проблема при фильтрации документов в 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);
                    }
                }
            }
...