PostGresql 常用sql函数备忘录

函数参考:http://www.cnblogs.com/wuhenke/archive/2010/08/02/1790747.html


导出数据 

C:\Program Files\PostgreSQL\8.4\bin>pg_dump.exe --host 127.0.0.1 --port 5432 --u

sername postgres  terra_postgis2 > c:\abc.sql


导入数据 

C:\Program Files\PostgreSQL\8.4\bin>psql -U postgres  terra_postgis2 < C:\postgi

s2_20140414.sql


查询点在面内

SELECT id,name,addr,ST_AsText(ST_GeomFromText(geom)) FROM geometry_data WHERE 1=1 AND name like '私%建%' AND addr like '%中%' AND ST_Within(geom,ST_GeomFromText('POLYGON((116.38272 39.90706,116.38350614443412 39.95209818446651))')) LIMIT 10 OFFSET 0


插入空间点

INSERT INTO geometry_data (name,addr,geom) VALUES (?,?,'POINT(116.3908 39.92549)')


查询显示已geojson显示

SELECT id, "name", addr, ST_AsGeoJson(geom) FROM geometry_data;


ST_Buffer缓冲区

select  ST_AsGeoJson(ST_Buffer('POINT(116.39 39.9)',1)) FROM geometry_data;

这个函数的第一个参数是要操作的空间几何数据,第二个参数长度(距离),第三个参数为一个整型,
这个函数返回一个空间数据类型,以当前第一个参数空间几何数据为参考点,返回小于等于距离的空间

注意:第二个参数,距离它的单位为空间数据单位(度),在运算时需要进行单位换算,最后转换成度,单位的换算关系如下:

1英里= 63360 米
1米=1/1852 海里
1海里= 1/60度
如果要进行具体的运算,需要进行一下单位换算,比如要求一个500米的范围,那么应该是


500*1/1852*1/60(度)


select  ST_AsText(ST_Buffer('POINT(116.39 39.9)',1)) FROM geometry_data;

ST_AsText(geometry)
将几何空间数据,转换成容易理解的空间数据文本格式,
例如:
(0,0 0,1 1,1 1,0 0,0)
转换后应该是这样的结果 POLYGON(0 0,0 1,1 1,1 0,0 0)


判断是什么状态

select GeometryType('LINESTRING(1 1,2 3,3 4,3 1,2 1,1 1)');


判断点数量:

select ST_NumPoints('LINESTRING(1 1,2 3,3 4,3 1,2 1,1 1)');


两点之间距离(笛卡尔距离,就是勾股定律得出来的,如下 勾三股四玄五 ):

select ST_Distance('POINT(119.3908 39.92549)', 'POINT(116.3908 35.92549)')


在SQL语句中,用以下的方式可以使用WKT格式定义几何对象:
           POINT(0 0) ——点
           LINESTRING(0 0,1 1,1 2) ——线
           POLYGON((0 0,4 0,4 4,0 4,0 0),(1 1, 2 1, 2 2, 1 2,1 1)) ——面
           MULTIPOINT(0 0,1 2) ——多点
           MULTILINESTRING((0 0,1 1,1 2),(2 3,3 2,5 4)) ——多线
           MULTIPOLYGON(((0 0,4 0,4 4,0 4,0 0),(1 1,2 1,2 2,1 2,1 1)), ((-1 -1,-1 -2,-2 -2,-2 -1,-1 -1))) ——多面
           GEOMETRYCOLLECTION(POINT(2 3),LINESTRING((2 3,3 4))) ——几何集合

           

以下语句可以使用WKT格式插入一个点要素到一个表中,其中用到的GeomFromText等函数在后面会有详细介绍:
           INSERT INTO table ( SHAPE, NAME )
           VALUES ( GeomFromText('POINT(116.39 39.9)', 4326), '北京');


5. PostGIS中的空间索引

           

数据库对多维数据的存取有两种索引方案,R-Tree和GiST(Generalized Search Tree),在PostgreSQL中的GiST比R-Tree的健壮性更好,因此PostGIS对空间数据的索引一般采用GiST实现。

           

以下的语句给sde模式中的cities表添加了一个空间索引shape_index_cities,在pgAdmin中也可以通过图形界面完成相同的功能。
           CREATE INDEX shape_index_cities
           ON sde.cities
           USING gist
           (shape);

           

另外要注意的是,空间索引只有在进行基于边界范围的查询时才起作用,比如“&&”操作


1. OGC标准函数 
           
           管理函数: 
           添加几何字段 AddGeometryColumn(, , , , , )
           删除几何字段 DropGeometryColumn(, , )
           检查数据库几何字段并在geometry_columns中归档 Probe_Geometry_Columns()
           给几何对象设置空间参考(在通过一个范围做空间查询时常用) ST_SetSRID(geometry, integer)
           
           几何对象关系函数 
           获取两个几何对象间的距离 ST_Distance(geometry, geometry)
           如果两个几何对象间距离在给定值范围内,则返回TRUE ST_DWithin(geometry, geometry, float)
           判断两个几何对象是否相等
           (比如LINESTRING(0 0, 2 2)和LINESTRING(0 0, 1 1, 2 2)是相同的几何对象) ST_Equals(geometry, geometry)
           判断两个几何对象是否分离 ST_Disjoint(geometry, geometry)
           判断两个几何对象是否相交 ST_Intersects(geometry, geometry)
           判断两个几何对象的边缘是否接触 ST_Touches(geometry, geometry)
           判断两个几何对象是否互相穿过 ST_Crosses(geometry, geometry)
           判断A是否被B包含 ST_Within(geometry A, geometry B)
           判断两个几何对象是否是重叠 ST_Overlaps(geometry, geometry)
           判断A是否包含B ST_Contains(geometry A, geometry B)
           判断A是否覆盖 B ST_Covers(geometry A, geometry B)
           判断A是否被B所覆盖 ST_CoveredBy(geometry A, geometry B)
           通过DE-9IM 矩阵判断两个几何对象的关系是否成立 ST_Relate(geometry, geometry, intersectionPatternMatrix)
           获得两个几何对象的关系(DE-9IM矩阵) ST_Relate(geometry, geometry)
           
           几何对象处理函数: 
           获取几何对象的中心 ST_Centroid(geometry)
           面积量测 ST_Area(geometry)
           长度量测 ST_Length(geometry)
           返回曲面上的一个点 ST_PointOnSurface(geometry)
           获取边界 ST_Boundary(geometry)
           获取缓冲后的几何对象 ST_Buffer(geometry, double, [integer])
           获取多几何对象的外接对象 ST_ConvexHull(geometry)
           获取两个几何对象相交的部分 ST_Intersection(geometry, geometry)
           将经度小于0的值加360使所有经度值在0-360间 ST_Shift_Longitude(geometry)
           获取两个几何对象不相交的部分(A、B可互换) ST_SymDifference(geometry A, geometry B)
           从A去除和B相交的部分后返回 ST_Difference(geometry A, geometry B)
           返回两个几何对象的合并结果 ST_Union(geometry, geometry)
           返回一系列几何对象的合并结果 ST_Union(geometry set)
           用较少的内存和较长的时间完成合并操作,结果和ST_Union相同 ST_MemUnion(geometry set)
           
           几何对象存取函数: 
           获取几何对象的WKT描述 ST_AsText(geometry)
           获取几何对象的WKB描述 ST_AsBinary(geometry)
           获取几何对象的空间参考ID ST_SRID(geometry)
           获取几何对象的维数 ST_Dimension(geometry)
           获取几何对象的边界范围 ST_Envelope(geometry)
           判断几何对象是否为空 ST_IsEmpty(geometry)
           判断几何对象是否不包含特殊点(比如自相交) ST_IsSimple(geometry)
           判断几何对象是否闭合 ST_IsClosed(geometry)
           判断曲线是否闭合并且不包含特殊点 ST_IsRing(geometry)
           获取多几何对象中的对象个数 ST_NumGeometries(geometry)
           获取多几何对象中第N个对象 ST_GeometryN(geometry,int)
           获取几何对象中的点个数 ST_NumPoints(geometry)
           获取几何对象的第N个点 ST_PointN(geometry,integer)
           获取多边形的外边缘 ST_ExteriorRing(geometry)
           获取多边形内边界个数 ST_NumInteriorRings(geometry)
           同上 ST_NumInteriorRing(geometry)
           获取多边形的第N个内边界 ST_InteriorRingN(geometry,integer)
           获取线的终点 ST_EndPoint(geometry)
           获取线的起始点 ST_StartPoint(geometry)
           获取几何对象的类型 GeometryType(geometry)
           类似上,但是不检查M值,即POINTM对象会被判断为point ST_GeometryType(geometry)
           获取点的X坐标 ST_X(geometry)
           获取点的Y坐标 ST_Y(geometry)
           获取点的Z坐标 ST_Z(geometry)
           获取点的M值 ST_M(geometry)
           
           几何对象构造函数 
           参考语义:
           Text:WKT
           WKB:WKB
           Geom:Geometry
           M:Multi
           Bd:BuildArea
           Coll:Collection ST_GeomFromText(text,[])
           
           ST_PointFromText(text,[])
           ST_LineFromText(text,[])
           ST_LinestringFromText(text,[])
           ST_PolyFromText(text,[])
           ST_PolygonFromText(text,[])
           ST_MPointFromText(text,[])
           ST_MLineFromText(text,[])
           ST_MPolyFromText(text,[])
           ST_GeomCollFromText(text,[])
           ST_GeomFromWKB(bytea,[])
           ST_GeometryFromWKB(bytea,[])
           ST_PointFromWKB(bytea,[])
           ST_LineFromWKB(bytea,[])
           ST_LinestringFromWKB(bytea,[])
           ST_PolyFromWKB(bytea,[])
           ST_PolygonFromWKB(bytea,[])
           ST_MPointFromWKB(bytea,[])
           ST_MLineFromWKB(bytea,[])
           ST_MPolyFromWKB(bytea,[])
           ST_GeomCollFromWKB(bytea,[])
           ST_BdPolyFromText(text WKT, integer SRID)
           ST_BdMPolyFromText(text WKT, integer SRID)
           2. PostGIS扩展函数

           

管理函数:

           

删除一个空间表(包括geometry_columns中的记录) DropGeometryTable([], )
           更新空间表的空间参考 UpdateGeometrySRID([], , , )
           更新空间表的统计信息 update_geometry_stats([, ])

你可能感兴趣的:(PostGresql 常用sql函数备忘录)