以下概念及函数均在在Oracle中配置地理数据库(sde库)中使用:

一.空间类型

1.概念:存储几何数据的数据类型。所有空间信息均存储在空间列中;不存在其他的要素表。将空间信息包含在一个字段中使得在 ArcGIS 之外访问空间数据变得更加容易。

2.用途:空间类型具有关联的函数或方法,可用于通过结构化查询语言 (SQL) 访问和操作数据

二.SRID

1.概念:空间参考标识符, 是与特定坐标系、容差和分辨率关联的唯一标识符。

2.用途:SRID 的填充方式及其所示含义取决于存储数据所用的数据库。

某些数据库和空间类型(如 PostgreSQL 中的 PostGIS 几何或 SQL Server 中的地理类型)使用预定义的 EPSG 代码子集,只可使用具有这些 SRID 的空间参考。

其他情况下(如 Oracle、PostgreSQL、IBM DB2 和 Informix 中的 ST_Geometry 类型)可使用具有 Esri 定义的 SRID 的空间参考。

三.空间参考

1.概念:包括一个 x、y、z 值的坐标系。在企业级地理数据库中,空间参考还包含容差值和分辨率值。所有这些信息组合在一起将有助于指示平面地图上的形状表示地球上的哪个位置。

2.应用:在企业级地理数据库(以及已安装 ST_Geometry 类型的 Oracle 或 PostgreSQL 数据库)中,所有空间参考系统都存储在地理数据库系统表中。

数据库和存储类型 地理数据库系统表

Oracle (ST_Geometry) sde.st_spatial_references

四.ST_Geometry 存储类型

1.概念:

ST_Geometry是一种用户定义数据类型 (UDT),使用该数据类型可定义存储空间数据的列。本身是抽象的、无法实例化的超类。但其子类可以实例化。实例化的数据类型是可定义为表列的数据类型,并且其类型值插入表列之中。虽然可以将列定义为类型 ST_Geometry,但是您无法将 ST_Geometry 值插入此列,因为无法对 ST_Geometry 进行实例化。相反,您可以插入子类值。

2.结构图:

3.子类

ST_Geometry 的子类分为两类:基础几何子类和同类集合子类。基础几何包括 ST_Point、ST_LineString 和 ST_Polygon,而同类集合包括 ST_MultiPoint、ST_MultiLineString 和 ST_MultiPolygon。与名称的含义一致,同类集合是基础几何的集合。除了共享基础几何属性之外,同类集合还具有某些自身的属性。

如下图:

4.常用函数

创建表community:

CREATE TABLE community(id integer,shape sde.st_geometry);

4.1 ST_Geometry: 

定义:通过熟知文本表示构造几何。

对于点线面:

语法:sde.st_geometry (wkt clob, srid integer)

示例:

INSERT INTO community(id, shape) VALUES (1,sde.st_geometry ('point (1 2)', 0));

INSERT INTO community(id, shape) VALUES (2,sde.st_geometry (1,2,null,null,0));

INSERT INTO community(id, shape) VALUES (3,sde.st_geometry ('linestring (33 2, 34 3, 35 6)', 0));

INSERT INTO community(id, shape) VALUES (4,sde.st_geometry ('polygon ((3 3, 4 6, 5 3, 3 3))', 0));

4.2 ST_Point

定义:以熟知文本对象或坐标和空间参考 ID 作为输入参数,返回 ST_Point 类型的对象。

语法:

sde.st_point (wkt clob, srid integer)

sde.st_point (x number, y number, srid integer)

sde.st_point (x number, y number, m number, srid integer)

sde.st_point (x number, y number, z number, srid integer)

sde.st_point (x number, y number, z number, m number, srid integer)

在 INSERT 语句将 ST_Point 几何插入到 shape列之前,首先用 ST_Point 函数将点坐标转换为 ST_Point 几何。

示例:

INSERT  INTO  community  VALUES (1,sde.st_point (10.01, 20.03, 0));

4.3 ST_PointFromText

定义:在Oracle中,ST_PointFromText 以点类型的熟知文本表示和空间参考 ID 作为输入参数,返回点对象。

语法:

sde.st_pointfromtext (wkt varchar2, srid integer)

在调用 INSERT 语句将点插入到 shape 列之前,首先使用 ST_Point 函数将点文本坐标转换为点格式。

示例:

INSERT  INTO  community  VALUES (1,sde.st_pointfromtext ('point (10.01 20.03)', 0));

4.4 ST_LineString

定义:是一个通过熟知文本表示构造线串的存取函数。

语法:sde.st_linestring (wkt clob, srid integer)

示例:

INSERT  INTO  community (id, shape) VALUES (1,sde.st_linestring ('linestring (750 150, 750 750)', 0));

4.5 ST_LineFromText

定义:以 ST_LineString 类型的熟知文本表示和空间参考 ID 作为输入,并返回 ST_LineString 类型的对象。

语法:sde.st_linefromtext (wkt clob, srid integer)

示例:INSERT  INTO community  VALUES (1,sde.st_linefromtext ('linestring (10.01 20.03, 35.93 19.04)', 0));

4.6 ST_Polygon

定义:存取器函数以熟知文本 (WKT) 表示和空间参考 ID (SRID) 作为输入参数,并生成 ST_Polygon 类型的对象。

语法:

sde.st_polygon (wkt clob, srid integer)

示例:

INSERT  INTO  community  VALUES ( 1, sde.st_polygon ('polygon ((10.01 20.03, 20.94 21.34, 35.93 10.04, 10.01 20.03))', 0));

4.7 ST_PolyFromText

定义:以熟知文本表示和空间参考 ID 作为输入参数,返回 ST_Polygon 类型的对象。

语法:

sde.st_polyfromtext (wkt clob, srid integer)

示例:

INSERT  INTO community  VALUES (1,sde.st_polyfromtext ('polygon ((10.01 20.03, 10.52 40.11, 30.29 41.56,31.78 10.74, 10.01 20.03))', 0));

4.8 ST_SRID

定义:以 ST_Geometry 对象作为输入参数,返回其空间参考 ID

语法:

sde.st_srid (shape sde.st_geometry)

示例:

SELECT sde.st_srid (shape) SRID FROM community ;

4.1 ST_AsText

定义:获取一个 ST_Geometry 对象,然后返回其可识别的文本表示。

语法:sde.st_astext (shape sde.st_geometry)

示例:

SELECT  id, sde.st_astext (shape) points FROM community;

ArcGis中地理数据库(sde)中概念及常见函数的更多相关文章

  1. 解决ArcGIS中因SDE或数据库配置问题而导致服务宕掉的一种思路

    文章版权由作者李晓晖和博客园共有,若转载请于明显处标明出处:http://www.cnblogs.com/naaoveGIS/. 1.背景 最近连续有两个项目现场出现了AGS服务荡掉的问题,一个是通州 ...

  2. 关于ArcGIS API for JavaScript中basemap的总结介绍(一)

    实际上basemap这个概念并不只在arcgis中才有,在Python中有一个matplotlib basemap toolkit(https://pypi.python.org/pypi/basem ...

  3. sde中导入shp报错

    在向sde中的数据集导入shp数据,发现报如下错误:

  4. WebLogic中的一些基本概念

    WebLogic中的一些基本概念   WebLogic 中的基本概念 上周参加了单位组织的WebLogic培训,为了便于自己记忆,培训后,整理梳理了一些WebLogic的资料,会陆续的发出来,下面是一 ...

  5. Activity中UI框架基本概念

    Activity中UI框架基本概念 Activity 是应用程序的基本组成部分,提供了可视的界面,UI容器, 与用户进行交互: 具体Acitivity是怎么样显示这些事视图元素以及响应事件交互的. 一 ...

  6. 往sde中导入要素类报错000732

    sde可以成功连接,可以在Server中注册. 但是向sde中导入要素类报错000732,如图所示. 点击红色圆圈提示 ERROR 000732. 将路径修改为绝对路径即可,如下图所示.

  7. ArcGIS API for Silverlight中加载Google地形图(瓦片图)

    原文:ArcGIS API for Silverlight中加载Google地形图(瓦片图) 在做水利.气象.土地等行业中,若能使用到Google的地形图那是再合适不过了,下面就介绍如何在ArcGIS ...

  8. Z-Stack协议中几个重要概念的理解

    1. 原语     ZigBee设备在工作时,各种不同的任务在不同的层次上执行,通过层的服务,完成所要执行的任务.每一层的服务主要完成两种功能:根据它的下层服务要求,为上层提供相应的服务:另一咱是根据 ...

  9. C#中一些易混淆概念总结

    C#中一些易混淆概念 这几天一直在复习C#基础知识,过程中也发现了自己以前理解不清楚和混淆的概念.现在给大家分享出来我的笔记: 一,.NET平台的重要组成部分都是有哪些 1)FCL (所谓的.NET框 ...

  10. 用人类社会工程学对C语言中的一些基本概念的剖析与理解

    最近在学C语言程序设计时总是遇到一些概念理解上的不清晰与混乱的地方,在一次偶然间想到了以前看过的一部电影<我是谁,没有一个系统是安全的>,里面的主角用社会工程学的想法结合黑客知识化险为夷, ...

随机推荐

  1. PHP flock() 函数

    定义和用法 flock() 函数锁定或释放文件. 如果成功,该函数返回 TRUE.如果失败,则返回 FALSE. 语法 flock(file,lock,block) 参数 描述 file 必需.规定要 ...

  2. luogu P1784 数独 dfs 舞蹈链 DXL

    LINK:数独 这道题好难 比DXL模板题要难上不少. 首先 还是考虑将行当做决策 那么 一共有\(9*9*9=729\) 个决策. 考虑列用来填充 需要有的条件为 某个位置能能放一次\(9*9\) ...

  3. luogu P4206 [NOI2005]聪聪与可可 期望dp 记忆化搜索

    LINK:聪聪与可可 这道题的核心是 想到如何统计答案. 如果设f[i][j]表示第i个时刻... 可以发现还需要统计位置信息 以及上一次到底被抓到没有的东西 不太好做. 两者的位置都在变化 所以需要 ...

  4. 牛客练习赛60 D 斩杀线计算大师

    LINK:斩杀线计算大师 给出a,b,c三个值 求出 ax+by+cz=k的x,y,z的正整数解 保证一定有解. 考虑两个数的时候 ax+by=k 扩展欧几里得可以解决. 三个数的时候 一个暴力的想法 ...

  5. bzoj 4238 电压

    LINK:电压 一张图 每个点可以为黑点或百点 每一条边的两端都必须为一黑一白.询问又多少条边满足除了这条边不满足条件其余所有边都满足条件. 分析一下这个所谓的条件 每一条边的两端必须为一黑一白 所以 ...

  6. 最后通牒!8月1日开始ios中国区下架全部无版号游戏

      据媒体报道,苹果早于7月8日就给中国游戏开发者发送邮件,要求游戏开发者必须在7月31日前提交游戏版号及相关文件,否则付费游戏将不可以在中国AppStore供应,8月1日期全部正式下架. ​   需 ...

  7. 糟糕,你写的 BUG 要被存1000年了!

    摘要:代码冰封,祖传千年! 把大象放在冰箱需要几步? 三步!把代码放在北极需要几步?纳尼? GitHub刚刚公布了一组照片,你写的代码(BUG)上周已经被打包运往北极保存. 只要你2月2日以前贡献过的 ...

  8. 2020年最新的过某宝滑块验证技术,Python大牛轻松搞定技术难题

    致谢: Charles未晞 Charles的皮卡丘 提供解决思路,此文实为借鉴. 前言: 利用selenium模拟登录淘宝,外界传言这个确实很难过,有各种轨迹检测. 但是我没想到淘宝的滑块验证码这么容 ...

  9. 蓝奏云数值验证码识别,python调用虹鱼图灵识别插件,超高正确率

    识别验证码一直是本人想要做的事情,一直在接触按键精灵,了解到有一个虹鱼图灵识别插件专门做验证码和图像识别,原理就是图片处理和制作字库识别,制作字库我一直觉得很麻烦,工程量太大.不管怎样,它能用能达到我 ...

  10. puppet单机模型

    puppet配置 命令 facter -p: 显示所有的变量 puppet apply [-v] [--noop] [-e 'puppet expression: 一般为include httpd等' ...