Кто-нибудь реализовал это или знает, будет ли это сложно реализовать / иметь какие-либо указатели?
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 не используется?
Ответы:
мы изучаем эту проблему на GitHub. Спасибо за отличное понимание и возможное решение. Вот ссылка на проблему: https://github.com/nhibernate/NHibernate.Spatial/issues/61
Я опубликую новые пакеты NuGet, как только это будет исправлено.
источник
Да, я думаю, что перекомпиляция DLL - лучшее решение на данный момент.
источник