栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

在MySQL中获取接近纬度的多边形

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

在MySQL中获取接近纬度的多边形

慢速版本(无空间索引):

SELECt  *FROM    mytableWHERe   MBRIntersects(mypolygon, LineString(Point(@X - @distance, @Y - @distance), Point(@X + @distance, @Y + @distance))

要使用空间索引,您需要对表格进行非规范化,以便将每个多边形顶点存储在其自己的记录中。

然后

SPATIAL INDEX
在包含顶点坐标的字段上创建,然后发出以下查询:

SELECt  DISTINCT polygon_idFROM    verticesWHERe   MBRContains(vertex, LineString(Point(@X - @distance, @Y - @distance), Point(@X + @distance, @Y + @distance))

如果您将

UTM
坐标存储在数据库中而不是纬度和经度,那么事情会容易得多。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/382733.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号