Критерии SpatialRestrictions.IsWithinDistance NHibernate.Spatial


95

Кто-нибудь реализовал это или знает, будет ли это сложно реализовать / иметь какие-либо указатели?

public static SpatialRelationCriterion IsWithinDistance(string propertyName, object anotherGeometry, double distance)
{
    // TODO: Implement
    throw new NotImplementedException();
}

из NHibernate.Spatial.Criterion.SpatialRestrictions

Я могу использовать "where NHSP.Distance (PROPERTY,: point)" в hql. Но хочу объединить этот запрос с моим существующим запросом критериев.

на данный момент я создаю грубый многоугольник и использую

criteria.Add(SpatialRestrictions.Intersects("PROPERTY", myPolygon));

РЕДАКТИРОВАТЬ Получил работу прототипа, перегрузив конструктор на SpatialRelationCriterion, добавив новый SpatialRelation.Distance

public static SpatialRelationCriterion IsWithinDistance(string propertyName, object anotherGeometry, double distance)
        {
            return new SpatialRelationCriterion(propertyName, SpatialRelation.Distance, anotherGeometry, distance);
        }

добавлено новое поле в SpatialRelationCriterion

private readonly double? distance;

public SpatialRelationCriterion(string propertyName, SpatialRelation relation, object anotherGeometry, double distance)
            : this(propertyName, relation, anotherGeometry)
        {
            this.distance = distance;
        }

Отредактированный ToSqlString

object secondGeometry = Parameter.Placeholder;
                if (!(this.anotherGeometry is IGeometry))
                {
                    secondGeometry = columns2[i];
                }

                if (distance.HasValue)
                {
                    builder.Add(spatialDialect.GetSpatialRelationString(columns1[i], this.relation, secondGeometry, distance.Value, true));
                }
                else
                {
                    builder.Add(spatialDialect.GetSpatialRelationString(columns1[i], this.relation, secondGeometry, true));
                }

перегруженный ISpatialDialect.GetSpatialRelationString

реализована перегрузка в MsSql2008SpatialDialect

public SqlString GetSpatialRelationString(object geometry, SpatialRelation relation, object anotherGeometry, double distance, bool criterion)
        {
            var x = new SqlStringBuilder(8)
                           .AddObject(geometry)
                           .Add(".ST")
                           .Add(relation.ToString())
                           .Add("(")
                           .AddObject(anotherGeometry)
                           .Add(")");

            if (criterion)
            {
                x.Add(" < ");
                x.AddObject(distance.ToString());
            }

            return x.ToSqlString();
        }

Не знаете, почему AddParameter не используется?


3
У меня та же проблема, и я пока не нашел полного патча / исправления / чего угодно. Решили или пошли с вариантом HQL?
Liedman

1
Думал, пошел с вышеуказанным подходом и перекомпилировал DLL для работы, но все еще был экспериментальным кодом.
Ян

2
@Amresh, вы не удовлетворены предложенным решением OP?
Eranga

Перекомпилируйте DLL, чтобы она заработала.
cowboy911,

По словам Рича Ландера из Microsoft , у вас может быть больше шансов, если вы поднимете этот вопрос на форумах NHibernate .
Энни

Ответы:


1

мы изучаем эту проблему на GitHub. Спасибо за отличное понимание и возможное решение. Вот ссылка на проблему: https://github.com/nhibernate/NHibernate.Spatial/issues/61

Я опубликую новые пакеты NuGet, как только это будет исправлено.


этот SO-вопрос тоже касается аналогичной проблемы с другим решением stackoverflow.com/questions/1833879/…
Сурья Пратап

0

Да, я думаю, что перекомпиляция DLL - лучшее решение на данный момент.

Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.