c# – 如何在Linq中使用DbGeography.Filter和Entity Framework 5?

c# – 如何在Linq中使用DbGeography.Filter和Entity Framework 5?,第1张

概述使用Entity Framework 5,可以在 Linq查询中使用SQL Server Spatial过程. 例如,使用DbGeography对象,您可以使用“Buffer()”方法,该方法将转换为SQL Server中的STBuffer.同样,Intersects()将转换为STIntersects. 这是一个有效的示例查询: var point = DbGeography.FromText( 使用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;

我想使用过滤器的可能性(因为这可以加快您的查询,如果准确性不是您主要关心的问题,请参阅此处:http://www.pauldmendoza.com/post/SQL-Server-Filter-vs-STInterects.aspx)
但是,我似乎无法在EF5中找到如何做到这一点.这可能吗?如果是的话:怎么样?

我正在使用sql Server 2008 R2.

解决方法 问这个问题有点太早了.我找到了这个:
http://msdn.microsoft.com/en-us/library/hh673622(v=vs.110).aspx

这可以像这样使用:

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

这转换为我想要的查询.

总结

以上是内存溢出为你收集整理的c# – 如何在Linq中使用DbGeography.Filter和Entity Framework 5?全部内容,希望文章能够帮你解决c# – 如何在Linq中使用DbGeography.Filter和Entity Framework 5?所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1218740.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-05
下一篇 2022-06-05

发表评论

登录后才能评论

评论列表(0条)

保存