oracle 创建SDO_Geometry表
Oracle Spatial由一坨的对象数据类型,类型方法,操作子,函数与过程组合而成。一个地理对象作为一个SDO_GEOMETRY对象保存在表的一个字段里。空间索引则由普通的DDL和DML语句来建立与维护。
本章主要说了一些例子演示如何建立,查询,索引空间数据。
简单的插入,索引与查询空间数据例子
本节演示一个很简单建立空间表,插入,建立索引,查询数据的过程。
场景是一个软饮料公司,用地理信息来表示他们的产品(可乐)在各个地区的情况。这些情况可以是:市场份额,竞争压力,增长潜力等等。而地区可以是邻近的市,州,省或国家。
我们要作的是:
1.建立一个表(COLA_MARKETS)来保存空间数据
2.插入四个(cola_a, cola_b, cola_c, cola_d)地区的数据
3.升级USER_SDO_GEOM_METADATA视图来反正这些地区的维度信息
4.建立空间索引(COLA_SPATIAL_IDX)
5.进行一些空间查询
- CREATE TABLE cola_markets (
- mkt_id NUMBER PRIMARY KEY,
- name VARCHAR2(32),
- shape SDO_GEOMETRY);
- INSERT INTO cola_markets VALUES(
- 1,
- 'cola_a',
- SDO_GEOMETRY(
- 2003, -- two-dimensional polygon
- NULL,
- NULL,
- SDO_ELEM_INFO_ARRAY(1,1003,3), -- one rectangle (1003 = exterior)
- SDO_ORDINATE_ARRAY(1,1, 5,7) -- only 2 points needed to
- -- define rectangle (lower left and upper right) with
- -- Cartesian-coordinate data
- )
- );
- -- The next two INSERT statements create areas of interest for
- -- Cola B and Cola C. These areas are simple polygons (but not
- -- rectangles).
- INSERT INTO cola_markets VALUES(
- 2,
- 'cola_b',
- SDO_GEOMETRY(
- 2003, -- two-dimensional polygon
- NULL,
- NULL,
- SDO_ELEM_INFO_ARRAY(1,1003,1), -- one polygon (exterior polygon ring)
- SDO_ORDINATE_ARRAY(5,1, 8,1, 8,6, 5,7, 5,1)
- )
- );
- INSERT INTO cola_markets VALUES(
- 3,
- 'cola_c',
- SDO_GEOMETRY(
- 2003, -- two-dimensional polygon
- NULL,
- NULL,
- SDO_ELEM_INFO_ARRAY(1,1003,1), -- one polygon (exterior polygon ring)
- SDO_ORDINATE_ARRAY(3,3, 6,3, 6,5, 4,5, 3,3)
- )
- );
- -- Now insert an area of interest for Cola D. This is a
- -- circle with a radius of 2. It is completely outside the
- -- first three areas of interest.
- INSERT INTO cola_markets VALUES(
- 4,
- 'cola_d',
- SDO_GEOMETRY(
- 2003, -- two-dimensional polygon
- NULL,
- NULL,
- SDO_ELEM_INFO_ARRAY(1,1003,4), -- one circle
- SDO_ORDINATE_ARRAY(8,7, 10,9, 8,11)
- )
- );
需要写将建立的表的空间图层的信息插入一条到USER_SDO_GEOM_METADATA
- INSERT INTO user_sdo_geom_metadata
- (TABLE_NAME,
- COLUMN_NAME,
- DIMINFO,
- SRID)
- VALUES (
- 'cola_markets',
- 'shape',
- SDO_DIM_ARRAY( -- 20X20 grid
- SDO_DIM_ELEMENT('X', 0, 20, 0.005),
- SDO_DIM_ELEMENT('Y', 0, 20, 0.005)
- ),
- NULL -- SRID
- );
- -- SRID
USER_SDO_GEOM_METADATA 在登陆PL/SQL后,Users→MDSYS→Objects→Views→USER_SDO_GEOM_METADATA
打开可以查看到下图(我已经插入了2个空间表的记录了)

可以看到这个插入的记录,点击红色方框初的任意一个,会出现下图:

- SDO_DIM_ARRAY( -- 20X20 grid
- SDO_DIM_ELEMENT('X', 0, 20, 0.005),
- SDO_DIM_ELEMENT('Y', 0, 20, 0.005)
- ),
就是这句sql的意思了,其中SDO_DIMNAME是一个二维的最大值和最小值的描述,SDO_LB是在X上面最小值,SDO_UB是X上面的最大值,SDO_TOLERANCE是指误差的大小,这里就是指0.005内的数据都会默认为一个数据。
第四步就是,建立空间索引(COLA_SPATIAL_IDX)
- CREATE INDEX cola_spatial_idx
- ON cola_markets(shape)
- INDEXTYPE IS MDSYS.SPATIAL_INDEX;
建立索引的目的是增加查询速度(理论上也可以不建立索引进行查询,但是实际中基本无法查询的出来)
建立好索引后会在tables中生成一个下面的表:

这个是个索引表:
可以在系统的索引表中找的到。
以上就创建完成了SDO_Geometry表了;可以开始空间分析了。
oracle 创建SDO_Geometry表的更多相关文章
- Oracle创建测试表
试中文排序的数据库版本: SQL> select * from v$version; BANNER ----------------------------------------------- ...
- oracle创建默认表空间---重要
当oracle创建数据库后,sys创建用户时还要有默认表空间.不创建默认表空间在导如项目时会有些数据表导入不成功! 由于时间仓促以截屏为例 之后会在刚刚那个空文件生成一个文件 ----------- ...
- Oracle 创建数据表
数据库中的每一个表都被一个模式(或用户)所拥有,因此表是一种典型的模式对象.在创建数据表时,Oracle 将在一个指定的表空间中为其分配存储空间.最初创建的表时一个空的逻辑存储结构,其中不包含任何数据 ...
- Oracle 创建数据表以及对数据表、字段、主外键、约束的操作
选择主键的原则: 最少性 尽量选择使用单个键作为主键 稳定性 尽量选择数值更新少的列作为主键 1.创建数据表(CREATE TABLE) --创建数据表Student create table Stu ...
- Oracle 创建/删除 表空间、用户、授权
首先以DBA连接到数据库:sqlplus / as sysdba; --创建表空间 create tablespace test_tablespace datafile 'D:\developer\o ...
- oracle 创建数据表空间和用户
--创建临时表空间(不必须)create temporary tablespace zwtest tempfile 'D:\Java\oracle\oradata\zwtest.dbf' size 5 ...
- oracle创建数据库表空间
1.创建表空间(存放数据) create tablespace xtba_datadatafile 'F:\ORACLE\ORADATA\ORCL\XTBA.DBF'size 50mautoexten ...
- oracle创建数据库表空间 用户 授权 导入 导出数据库
windows下可以使用向导一步一步创建数据库,注意编码. windows连接到某一个数据库实例(不然会默认到一个实例下面):set ORACLE_SID=TEST --登录开始创建表空间及可以操作的 ...
- Oracle 创建外部表
Oracle 外部表能迅速的将海量的数据导入到数据库里面,外部表的创建使用步骤如下: 1 创建一个Directory:必须用sys用户创建,用户存放外部数据文件. create directory D ...
随机推荐
- css属性 盒子模型
一. css属性相关 1.宽和高 1.width可以为元素设置宽度 2. height可以为元素设置高度 3.只有块级标签才可以设置宽度和高度,内联标签并不能设置宽度和高度,及时设置了也不 ...
- 进入wordpress中的模板文件
Wordpress的页面结构 一个简单的wordpress由 头部.内容.页脚组成,每个块中的每一个都由当前wordpress主题中模板文件生成. eg: 头:包含重要的信息,一般都是网页的头部. 内 ...
- java——并查集 UnionFind
时间复杂度: O(log*n),近乎是O(1)级别的 UnionFind 接口: public interface UF { int getSize(); boolean isConnected(in ...
- my.赚钱
http://mhxy.gamedog.cn/201503/999433.html (发表于 2015-03-19) 梦幻西游手游四种赚钱技巧翻身做土豪教程,在游戏中玩家需要知道的就是赚钱方法是非 ...
- 转 python3中SQLLIT编码与解码之Unicode与bytes
#########sample########## sqlite3.OperationalError: Could not decode to UTF-8 column 'logtype' with ...
- appium使用常见问题汇总--持续更新
问题1:使用adb devices查看连接设备,提示unauthorized 解决方案:进入进程管理,关闭adb进程,然后再查看连接设备 问题2:adb connect ip提示远程计算机积极拒绝,无 ...
- spring事务的传播性
<!--配置事务传播特性 --><tx:advice id = "txAdvice" transaction-manager = "txManage&q ...
- Head First 设计模式笔记(适配器)
1.定义: 将一个类的接口转换成客户期望的另外一个接口.适配器让原来不兼容的类可以合作无间. 例子:插座转接头. 2.类图: 3.说明: 埋坑 4.例子 埋坑
- [转]FireFox与IE 下js兼容触发click事件的代码
本文转自:http://www.jb51.net/article/16549.htm FireFox与IE 下js兼容触发click事件 ,对于需要兼容这两者的朋友,就需要参考下下面的代码了<a ...
- Smaug Coverage