- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我使用 PostgreSQL 和 GIS 扩展来存储 map 数据,以及 OpenLayers、GeoServer 等。给定一个多边形,例如对于一个邻域,我需要找到存储在多边形内的某个表(例如交通灯、餐馆)中的所有纬度/经度点。或者,给定一组多边形,我想找到每个多边形内的点集(如 GROUP BY 查询,而不是迭代每个多边形)。
这些函数是我需要编程的东西,还是可用的功能(作为扩展 SQL)?请详细说明。
另外,对于我拥有的简单 2D 数据,我实际上需要 GIS 扩展(GPL 许可证是一个限制)还是 PostgreSQL 就足够了?
谢谢!
最佳答案
在 PostGIS 中,您可以使用边界框运算符来查找候选对象,这非常有效,因为它使用 GiST 索引。然后,如果需要严格匹配,请使用 contains 运算符。
类似的东西
SELECT
points,neighborhood_name from points_table,neighborhood
WHERE
neighborhood_poly && points /* Uses GiST index with the polygon's bounding box */
AND
ST_Contains(neighborhood_poly,points); /* Uses exact matching */
是否需要这个,取决于你的要求。为了使上述工作正常进行,您当然需要安装 PostGIS 和 GEOS。但是,如果边界框匹配就足够了,您可以简单地用 SQL 进行编码,而不需要 PostGIS。
如果需要精确匹配,则包含的算法是公开可用的,但要有效地实现它们,需要付出一些努力在库中实现它,然后从 SQL 调用该库(就像 GEOS)。
关于polygon - 在PostGIS中,如何找到多边形内的所有点?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1873083/
例如,我有一个父类Author: class Author { String name static hasMany = [ fiction: Book,
代码如下: dojo.query(subNav.navClass).forEach(function(node, index, arr){ if(dojo.style(node, 'd
我有一个带有 Id 和姓名的学生表和一个带有 Id 和 friend Id 的 Friends 表。我想加入这两个表并找到学生的 friend 。 例如,Ashley 的 friend 是 Saman
我通过互联网浏览,但仍未找到问题的答案。应该很容易: class Parent { String name Child child } 当我有一个 child 对象时,如何获得它的 paren
我正在尝试创建一个以 Firebase 作为我的后端的社交应用。现在我正面临如何(在哪里?)找到 friend 功能的问题。 我有每个用户的邮件地址。 我可以访问用户的电话也预订。 在传统的后端中,我
我主要想澄清以下几点: 1。有人告诉我,在 iOS 5 及以下版本中,如果您使用 Game Center 设置多人游戏,则“查找 Facebook 好友”(如与好友争夺战)的功能不是内置的,因此您需要
关于redis docker镜像ENTRYPOINT脚本 docker-entrypoint.sh : #!/bin/sh set -e # first arg is `-f` or `--some-
我是一名优秀的程序员,十分优秀!