Kryteria SpatialRestrictions.IsWithinDistance NHibernate.Spatial

95

Czy ktoś to zaimplementował lub wie, czy byłoby to trudne / ma jakieś wskazówki?

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

z NHibernate.Spatial.Criterion.SpatialRestrictions

Mogę użyć wyrażenia „gdzie NHSP.Distance (PROPERTY,: point)” w hql. Ale chcę połączyć to zapytanie z moim istniejącym zapytaniem Kryteria.

na razie tworzę szorstki wielokąt i używam

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

EDYCJA Uzyskano prototyp działający przez przeciążenie konstruktora na SpatialRelationCriterion, dodając nowy SpatialRelation.Distance

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

dodano nowe pole do SpatialRelationCriterion

private readonly double? distance;

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

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

przeciążony ISpatialDialect.GetSpatialRelationString

zaimplementowano przeciążenie w 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();
        }

Nie wiesz, dlaczego AddParameter nie jest używany?

Ian
źródło
3
Mam ten sam problem i do tej pory nie znalazłem żadnej pełnej łatki / poprawki / czegokolwiek. Czy rozwiązałeś to, czy wybrałeś wariant HQL?
Liedman,
1
Think poszedł z powyższym podejściem i ponownie skompilował dll do pracy, ale nadal był kodem eksperymentalnym.
Ian
2
@Amresh, czy nie jesteś zadowolony z proponowanego rozwiązania, które podał OP?
Eranga
Ponownie skompiluj bibliotekę DLL, aby działała.
cowboy911
Według Richa Landera z Microsoft , możesz mieć większe szanse, jeśli poruszysz ten problem na forach NHibernate .
Annie,

Odpowiedzi:

0

Tak, myślę, że na razie Recompile DLL jest najlepszym rozwiązaniem.

ilce
źródło