我的城市已经使用 PostGIS 定义了一些 城市振兴边界 我已经将城市 街区内的边界和 建筑物内的边界分隔开来。我现在要做的是用两个新列更新建筑物表,将它们与它们所在的块相关联。
以下是 Blocks 表的示例,两列 qd_setor 和 qd_fiscal 是我需要传递给 Buildings 表的信息
qd_setor | qd_fiscal | wkb_geometry
----------+-----------+---------------
041 | 038 | 010600...
086 | 302 | 010600...
041 | 076 | 010600...
075 | 054 | 010600...
019 | 055 | 010600...
这是 Buildings 表的示例:
ed_id | ed_area | ed_altura | ed_distrito | wkb_geometry
---------+---------+-----------+---------------+--------------
2739627 | 187.211 | 6.922 | SANTA_CECILIA | 010600...
2739628 | 240.39 | 43.382 | SANTA_CECILIA | 010600...
2739781 | 51.758 | 4.668 | SANTA_CECILIA | 010600...
2739629 | 388.264 | 52.907 | SANTA_CECILIA | 010600...
这是我用来创建块和建筑物表的查询:
CREATE TABLE quadras_opurb AS
SELECT q.qd_setor, q.qd_fiscal, q.wkb_geometry
FROM quadra_fiscal q
WHERE EXISTS (
SELECT ou_nome
FROM op_urbana_valid o
WHERE
ST_Intersects(q.wkb_geometry, o.wkb_geometry)
);
这是预期的结果,所以一旦完成,我就不必测试所需块和建筑物之间的交叉点,我可以通过 qd_setor 和 qd_fiscal 进行过滤:
ed_id | ed_area | ed_altura | ed_distrito | wkb_geometry | qd_setor | qd_fiscal
---------+---------+-----------+---------------+--------------+----------+------------
2739627 | 187.211 | 6.922 | SANTA_CECILIA | 010600... | 041 | 038
2739628 | 240.39 | 43.382 | SANTA_CECILIA | 010600... | 041 | 038
2739781 | 51.758 | 4.668 | SANTA_CECILIA | 010600... | 041 | 038
2739629 | 388.264 | 52.907 | SANTA_CECILIA | 010600... | 086 | 302
2739631 | 187.244 | 22.865 | SANTA_CECILIA | 010600... | 086 | 302
请注意 qd_setor 和 qd_fiscal 将重复多次,因为一个块中有多个建筑物。
谢谢您的帮助!