Фильтрация нескольких операций Geo Near в запросе приводит к ошибке

Я сделал фильтр для выполнения геопространственного запроса к данным из моей базы данных Mongodb, и этот фильтр работает нормально, пока я не выполню операцию "И" для этого фильтра с другим геопространственным фильтром, но указываю на другое свойство в запрашиваемой коллекции. Когда я добавляю этот фильтр, я получаю исключение:

Сообщение: MongoDB.Driver.MongoCommandException: Не удалось найти команду: слишком много выражений geoNear.

Вот первый фильтр,


                var point = GeoJson.Point(GeoJson.Geographic(longitude: annEntityaAttr.CollectionLocation.Longitude,
                    latitude: annEntityaAttr.CollectionLocation.Latitude));
                filter = Builders<AnnouncementEntity>.Filter.Near(a => a.CollectionLocation, point, annEntityaAttr.MaxDistanceFromLocationInKM * metersFor1KM);

Вот как я добавляю второй фильтр:

var point = GeoJson.Point(GeoJson.Geographic(longitude: annEntityaAttr.DepositLocation.Longitude,
                    latitude: annEntityaAttr.DepositLocation.Latitude));
                var secondFilter = Builders<AnnouncementEntity>.Filter.Near(a => a.DepositLocation, point, annEntityaAttr.MaxDistanceFromLocationInKM * metersFor1KM);

filter = filter & secondFilter;

Обычно, когда применяется & к двум фильтрам, это работает, но в этом случае это не радует, есть ли у кого-то решение для этого?

0 ответов

Вы можете выполнять только один гео-запрос к одной коллекции за раз. если вы должны сохранить два поля координат в одном документе, вам придется выполнить два отдельных географических запроса, а затем пересечь результаты на стороне клиента. также вам нужно будет создать 2 геоиндекса и указать ключ индекса при запросе. вот пример программы, которая использует мою библиотеку MongoDB.Entities для достижения того, что вам нужно.

using MongoDB.Entities;
using MongoDB.Driver;
using System.Linq;

namespace Stackru
{
    public class Program
    {
        public class Announcement : Entity
        {
            public Coordinates2D CollectionLocation { get; set; }
            public Coordinates2D DepositLocation { get; set; }
            public double DistanceMeters { get; set; }
        }

        static void Main(string[] args)
        {
            new DB("test");

            DB.Index<Announcement>()
              .Key(a => a.CollectionLocation, KeyType.Geo2DSphere)
              .Create();

            DB.Index<Announcement>()
              .Key(a => a.DepositLocation, KeyType.Geo2DSphere)
              .Create();

            (new Announcement
            {
                DepositLocation = new Coordinates2D(48.8539241, 2.2913515),
                CollectionLocation = new Coordinates2D(48.796964, 2.137456)
            }).Save();

            var searchPointA = new Coordinates2D(48.796964, 2.137456);

            var queryA = DB.GeoNear<Announcement>(
                                NearCoordinates: searchPointA,
                                DistanceField: a => a.DistanceMeters,
                                IndexKey: "CollectionLocation",
                                MaxDistance: 10);

            var searchPointB = new Coordinates2D(48.8539241, 2.2913515);

            var queryB = DB.GeoNear<Announcement>(
                                NearCoordinates: searchPointB,
                                DistanceField: a => a.DistanceMeters,
                                IndexKey: "DepositLocation",
                                MaxDistance: 10);

            var resultA = queryA.ToList();
            var resultB = queryB.ToList();

            var common = resultA.Where(a => resultB.Any(b => b.ID == a.ID)).ToArray();
        }
    }
}

следующие два запроса $geoNear будут отправлены для поиска местоположений:

[
    {
        "$geoNear": {
            "near": {
                "type": "Point",
                "coordinates": [
                    48.8539241,
                    2.2913515
                ]
            },
            "distanceField": "DistanceMeters",
            "spherical": true,
            "maxDistance": NumberInt("10"),
            "key": "DepositLocation"
        }
    }
]

[
    {
        "$geoNear": {
            "near": {
                "type": "Point",
                "coordinates": [
                    48.796964,
                    2.137456
                ]
            },
            "distanceField": "DistanceMeters",
            "spherical": true,
            "maxDistance": NumberInt("10"),
            "key": "CollectionLocation"
        }
    }
]
Другие вопросы по тегам