Ganos sfmesh已经实现了sfmesh、meshgeom类型的原生3D空间索引。
使用方法
sfmesh类型
- 创建带sfmesh字段的表。
create table mesh_gist_test ( id integer, the_mesh sfmesh );
- 插入sfmesh记录。
insert into mesh_gist_test values(1, '{"version" : 1, "root" : 0, "meshgeoms" : ["MESHGEOM(PATCH(INDEXSURFACE Z (VERTEX(307248.723802283 296449.440306073 6500.00004882812,307248.723802283 296449.440306073 100,307258.460240141 296449.440306073 6500.00004882812,307258.460240141 296449.440306073 100,307258.460240141 296474.440306263 6500.00004882812,307258.460240141 296474.440306263 100,307248.723802283 296474.440306263 6500.00004882812,307248.723802283 296474.440306263 100),INDEX((0,1,2),(3,2,1),(4,5,6),(7,6,5),(3,1,7),(7,5,3),(2,3,4),(5,4,3),(0,2,4),(4,6,0),(1,0,7),(6,7,0)))))"], "primitives" : [{"meshgeom" : 0}], "nodes" : [{"primitive" : 0}]}'::mesh);
- 在sfmesh字段创建GIST 3D空间索引。
create index mesh_gist_test_idx on mesh_gist_test using gist (the_mesh);
meshgeom类型
- 创建带meshgeom字段的表。
create table meshgeom_gist_test as select id, meshgeom(the_mesh) as the_mgeom from mesh_gist_test;
- 在meshgeom字段创建GIST 3D空间索引。
CREATE INDEX meshgeom_gist_test_idx on meshgeom_gist_test using gist (the_mgeom);