函数参考:http://www.cnblogs.com/wuhenke/archive/2010/08/02/1790747.html
导出数据
C:Program FilesPostgreSQL8.4bin>pg_dump.exe --host 127.0.0.1 --port 5432 --u
sername postgres terra_postgis2 > c:abc.sql
导入数据
C:Program FilesPostgreSQL8.4bin>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,geom) VALUES (?,?,'POINT(116.3908 39.92549)')
查询显示已geojson显示
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)',51); font-family:Arial; font-size:14px; line-height:26px"> ST_AsText(geometry) 将几何空间数据,转换成容易理解的空间数据文本格式, 例如: (0,0 0,1 1,0) 转换后应该是这样的结果 POLYGON(0 0,0 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,51); font-family:Arial; font-size:14px; line-height:26px"> 两点之间距离(笛卡尔距离,就是勾股定律得出来的,如下 勾三股四玄五 ):
select ST_Distance('POINT(119.3908 39.92549)','POINT(116.3908 35.92549)')
在SQL语句中,用以下的方式可以使用WKT格式定义几何对象: POINT(0 0) ——点 LINESTRING(0 0,1 2) ——线 POLYGON((0 0,4 0,4 4,0 4,0 0),(1 1,2 2,1 2,1 1)) ——面 MULTIPOINT(0 0,1 2) ——多点 MULTILINESTRING((0 0,1 2),(2 3,3 2,5 4)) ——多线 MULTIPOLYGON(((0 0,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,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,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([,]) (编辑:李大同)
【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!
|