Kriteria Batasan Spasial.IsWithinDistance NHibernate.Spatial

95

Adakah yang menerapkan ini, atau tahu apakah akan sulit untuk menerapkan ini / punya petunjuk?

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

dari NHibernate.Spatial.Criterion.SpatialRestrictions

Saya dapat menggunakan "di mana NHSP.Distance (PROPERTY,: point)" di hql. Tetapi ingin menggabungkan kueri ini dengan kueri Kriteria saya yang sudah ada.

untuk saat ini saya membuat poligon kasar, dan menggunakan

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

EDIT Mendapatkan prototipe yang bekerja dengan membebani konstruktor pada SpatialRelationCriterion, menambahkan SpatialRelation.Distance baru

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

menambahkan bidang baru ke SpatialRelationCriterion

private readonly double? distance;

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

ToSqlString telah diedit

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 kelebihan beban

menerapkan kelebihan beban di 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();
        }

Tidak yakin mengapa AddParameter tidak digunakan?

Ian
sumber
3
Saya memiliki masalah yang sama, dan belum menemukan tambalan / perbaikan / apa pun yang lengkap sejauh ini. Apakah Anda menyelesaikannya, atau Anda menggunakan varian HQL?
Liedman
1
Berpikir berjalan dengan pendekatan di atas, dan mengompilasi ulang dll untuk bekerja, tetapi masih kode eksperimental.
Ian
2
@ Amresh apakah Anda tidak puas dengan solusi yang diusulkan OP berikan?
Eranga
Kompilasi ulang DLL agar berfungsi.
cowboy911
Menurut Rich Lander dari Microsoft , Anda mungkin memiliki kesempatan yang lebih baik jika Anda mengangkat masalah ini di forum NHibernate .
Annie

Jawaban:

0

Ya, saya pikir Recompile DLL adalah solusi terbaik untuk saat ini.

ilce
sumber