c# – 如何在Linq中使用DbGeography.Filter和Entity Framework 5
发布时间:2020-12-16 01:59:37 所属栏目:百科 来源:网络整理
导读:使用Entity Framework 5,可以在 Linq查询中使用SQL Server Spatial过程. 例如,使用DbGeography对象,您可以使用“Buffer()”方法,该方法将转换为SQL Server中的STBuffer.同样,Intersects()将转换为STIntersects. 这是一个有效的示例查询: var point = DbGeog
使用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) 我正在使用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; 这转换为我想要的查询. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- ruby-on-rails – 如何从rails 3中的响应中删除Set-Cookie标
- c – 如何使用具有两列的模型获取QComboBox的当前值?
- postgresql – 我如何知道为表创建的索引?
- ruby-on-rails – 为什么Bundler不会在OS X 10.8上安装json
- ruby-on-rails – 如何使Rails迁移以当前RAILS_ENV为条件?
- iphone – Xcode不会放弃资源文件
- ruby-on-rails – 我如何在轨道中有条件地设置>?
- 获取oracle.sql.array的长度
- 【Chart.js】通过Ajax请求JSON数据来绘制图表
- Cocos Studio制作帧动画