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