I got an existing advanced search method which is a collection survival FormCollection
checks Search criteria, and if present, adds a criteria for search such as
public IList
I have also found basic distance searching to find out how far every residence is from the search criteria HBM for the query
& Lt; Sql-query name = "Residence.Nearest" & gt; & Lt; Return alias = "residence" class = "residences domain. Estimate, residence" /> & Lt; Return-scaler column = "distance" type = "float" /> SELECT R. *, dbo.GetDistance (: point, R.Coordinate) AS R distance Distance from R & lt; Distance by 10 orders & lt; / Sql-query & gt;
I had to define a function to calculate the distance, because there was no way to get NHibernate to avoid colon geographical function:
Create Function dbo.GetDistance (@firstPoint nvarchar (100), @secondPoint geometry) returns returns Geography :: STGeomFromText (@firstPoint, 4326) .STDistance start float (@ secondPoint.STAsText ()) / 1609.344 end
and the repository calls the named query as such:
return session .GetNamedQuery ("Residence.Nearest") .Setstring C ( "point", String.Format ( "POINT ({0} {1})", latitude, longitude). List ();
So my question is: I have two How to add (or start with scratch), so I can filter advanced search results to include only residences within 10 miles of search location?
Update I've tried to use NHibernate.Spatial with the following code:
criteria.Add (SpatialExpression.IsWithinDistance ( "coordination", the new coordinates (latitude, longitude), 10));
but SpatialExpression.IsWithinDistance
returned a System.NotImplementedException
.
have you seen? This can provide an easy solution to your problem.
optional
and Target your special database platform. After this, you can combine your distance function with other parameters. ICriterion
is to implement your own - if you get the AbstractCriterion
if it is not too difficult
No comments:
Post a Comment