Критерії Просторові обмеження. Це в межах відстані


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));

EDIT Отримав прототип, що працює, перевантажуючи конструктор на 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, вас не влаштовує запропоноване рішення, яке дав ОП?
Eranga

Перекомпілюйте DLL, щоб вона працювала.
cowboy911

За словами Річа Лендера з Microsoft , ви можете мати більше шансів, якщо піднімете цю проблему на форумах NHibernate .
Енні

Відповіді:


1

ми розглядаємо це питання на GitHub. Дякуємо за чудове розуміння та можливе рішення. Ось посилання на випуск: https://github.com/nhibernate/NHibernate.Spatial/issues/61

Я опублікую нові пакети NuGet, як тільки це буде виправлено.


це ПИТАННЯ теж стосується подібної проблеми з іншим рішенням stackoverflow.com/questions/1833879/…
Суря Пратап,

0

Так, я думаю, що перекомпілювати DLL на сьогоднішній день є найкращим рішенням.

Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.