Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/csharp/315.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/7/sql-server/25.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# 如何在具有实体框架5的Linq中使用DbGeography.Filter?_C#_Sql Server_Linq_Entity Framework_Spatial - Fatal编程技术网

C# 如何在具有实体框架5的Linq中使用DbGeography.Filter?

C# 如何在具有实体框架5的Linq中使用DbGeography.Filter?,c#,sql-server,linq,entity-framework,spatial,C#,Sql Server,Linq,Entity Framework,Spatial,使用Entity Framework 5,可以在Linq查询中使用SQL Server Spatial过程 例如,使用DbGeography对象,可以使用“Buffer()”方法,该方法将在SQL Server中转换为STBuffer。同样,Intersects()将转换为STIntersects 这是一个有效的查询示例: var point = DbGeography.FromText(string.Format("POINT({1} {0})", latitude, longitude)

使用Entity Framework 5,可以在Linq查询中使用SQL Server Spatial过程

例如,使用DbGeography对象,可以使用“Buffer()”方法,该方法将在SQL Server中转换为STBuffer。同样,Intersects()将转换为STIntersects

这是一个有效的查询示例:

  var point = DbGeography.FromText(string.Format("POINT({1} {0})", latitude, longitude), 4326);
  var query = from person in persons
              let region = point.Buffer(radius)
              where person.Location.Intersects(region)
              select person;
我想使用过滤器的可能性(因为这可以加快您的查询速度,如果准确性不是您主要关心的问题,正如这里所指出的:) 然而,我似乎找不到如何在EF5中做到这一点。这可能吗?如果是,怎么做


我正在使用SQL Server 2008 R2。

问这个问题有点太早了。我发现:

这可以像这样使用:

  var point = DbGeography.FromText(string.Format("POINT({1} {0})", latitude, longitude), 4326);
  var query = from person in persons
              let region = point.Buffer(radius)
              where SqlSpatialFunctions.Filter(person.Location, region) == true
              select person; 

这就转化为我想要的查询。

简单说明一下-“POINT”期望第一个经度而不是纬度这是真的,但我在{0}之前添加了{1},所以示例是正确的。我没有注意到一个最佳半径值是什么?