天天看點

PostGIS之路--AddGeometryColumn函數--添加一個幾何類型字段

1、AddGeometryColumn

       添加一個幾何類型字段到已經存在的可用表中,預設情況下使用類型修飾符定義限制。該i函數實作版本較早,支援3D但不能删除z,也支援添加圓和曲面。

函數:

text AddGeometryColumn(varchar table_name, varchar column_name, integer srid, varchar type, integer dimension, booleanuse_typmod=true);

text AddGeometryColumn(varchar schema_name, varchar table_name, varchar column_name, integer srid, varchar type, integer dimension, boolean use_typmod=true);

text AddGeometryColumn(varchar catalog_name, varchar schema_name, varchar table_name, varchar column_name, integer srid, varchar type, integer dimension, boolean use_typmod=true);

    注意事項:

     (1)srid必須在SPATIAL_REF_SYS表中

     (2)添加到的表必須存在

     (3)添加的類型存在

例如:

CREATE SCHEMA my_schema;

CREATE TABLE my_schema.my_spatial_table (id serial);

SELECT AddGeometryColumn ('my_schema','my_spatial_table','geom',4326,'POINT',2);

SELECT AddGeometryColumn ('my_schema','my_spatial_table','geom_c',4326,'POINT',2, false);

SELECT AddGeometryColumn('my_schema','my_spatial_table','geomcp_c',4326,'CURVEPOLYGON',2,false);

2、DropGeometryColumn

      從空間表中删除某一幾何類型字段。(與AddGeometryColumn類似)

text DropGeometryColumn(varchar table_name, varchar column_name);

text DropGeometryColumn(varchar schema_name, varchar table_name, varchar column_name);

text DropGeometryColumn(varchar catalog_name, varchar schema_name, varchar table_name, varchar column_name);

SELECT DropGeometryColumn ('my_schema','my_spatial_table','geom');

ALTER TABLE my_schema.my_spatial_table DROP column geom;2.0版本裡也可用該方法删除字段。

3、DropGeometryTable

     删除一個表和所有的空間字段。

boolean DropGeometryTable(varchar table_name);

boolean DropGeometryTable(varchar schema_name, varchar table_name);

boolean DropGeometryTable(varchar catalog_name, varchar schema_name, varchar table_name);

SELECT DropGeometryTable ('my_schema','my_spatial_table');

DROP TABLE my_schema.my_spatial_table;

4、擷取PostGIS版本相關資訊函數(以下函數均傳回text)

PostGIS_Full_Version          傳回所有版本資訊

PostGIS_GEOS_Version        傳回GEOS類庫的版本資訊,及是否可用。

PostGIS_LibXML_Version      傳回libxml2庫的版本資訊

PostGIS_Lib_Build_Date       傳回PostGIS類庫建構時間

PostGIS_Lib_Version            傳回PostGIS類庫版本

PostGIS_PROJ_Version         傳回PROJ4類庫的版本資訊,及是否可用。

PostGIS_Scripts_Build_Date  傳回Scripts建構時間

PostGIS_Scripts_Installed     傳回安裝腳本版本

PostGIS_Scripts_Released    傳回解除安裝腳本版本

PostGIS_Version                  傳回PostGIS版本資訊

SELECT PostGIS_Full_Version();

SELECT PostGIS_GEOS_Version();

SELECT PostGIS_LibXML_Version();

SELECT PostGIS_Lib_Build_Date();

SELECT PostGIS_Lib_Version();

SELECT PostGIS_PROJ_Version();

SELECT PostGIS_Scripts_Build_Date();

SELECT PostGIS_Scripts_Installed();

SELECT PostGIS_Scripts_Released();

SELECT PostGIS_Version();定義的

5、Populate_Geometry_Columns

使用時,須確定定義的字段可修改或者空間參考已經注冊。use_typmod=false時,獲得過去行為。

text Populate_Geometry_Columns(boolean use_typmod=true);

int Populate_Geometry_Columns(oid relation_oid, boolean use_typmod=true);

注意:

2.0.0版本改變:現在使用類型修飾符替換檢查限制限制幾何類型。你仍可使用檢查修飾替換新use_typmod,設定為 false。

2.0.0版本加強:介紹了use_typmod可選參數允許被控制,如果列被建立typmodifiers或檢查限制。

CREATE TABLE public.myspatial_table_cs(gid serial, geom geometry);

INSERT INTO myspatial_table_cs(geom) VALUES(ST_GeomFromText('LINESTRING(1 2, 3 4)',4326) );

SELECT Populate_Geometry_Columns('public.myspatial_table_cs'::regclass, false);

6、UpdateGeometrySRID

修改空間參考SRID,也可用ST_SetSRID,注意修改的SRID必須是模式中存在的。

text UpdateGeometrySRID(varchar table_name, varchar column_name, integer srid);

text UpdateGeometrySRID(varchar schema_name, varchar table_name, varchar column_name, integer srid);

text UpdateGeometrySRID(varchar catalog_name, varchar schema_name, varchar table_name, varchar column_name, integer srid);

--建立表
CREATE TABLE public.oyz_common_poi (
    id integer NOT NULL,
    name character varying(256),
    longitude double precision,
    latitude double precision,
    address character varying(256),
    phone character varying(64),
    type character varying(256),
    real_type character varying(64),
    self_type character varying(64),
    pos character varying(512),
    height double precision,
    image character varying(32),
    geom geometry(geometry,4326)
);

--插入資料
INSERT INTO public.oyz_common_poi VALUES (111287, '美薩木鋁門窗', 101.7640832, 36.66519532, '青海省西甯市城北區朝陽東路62号西60米', NULL, '購物;家居建材', '購物', NULL, NULL, 2579.336, 'shopping');
INSERT INTO public.oyz_common_poi VALUES (111506, '友誼手機直銷', 101.7328943, 36.63458114, '海湖路29号', NULL, '購物;家電數位', '購物', NULL, NULL, 2574.102, 'shopping');
INSERT INTO public.oyz_common_poi VALUES (111634, '永昌通訊', 101.7533861, 36.59198285, '城西區142号附近', NULL, '購物;家電數位', '購物', NULL, NULL, 2484.445, 'shopping');

--查詢資料
select * from oyz_common_poi;

--如果忘記添加幾何geometry字段
-- 添加:幾何 geometry 資料類型
SELECT AddGeometryColumn('','oyz_common_poi','geom','4326','geometry',2);
-- 批量拼接并設定geom字段
update oyz_common_poi set geom = concat('SRID=4326;POINT (',longitude,' ',latitude,')')      

參考連結:http://postgis.net/docs/AddGeometryColumn.html