Oracle Spatial建表学习步骤详解

Oracle Spatial建表学习的步骤是本文我们主要要介绍的内容,步骤如下:

在大兴安岭等地区,都构建了全面的区域性战略布局,加强发展的系统性、市场前瞻性、产品创新能力,以专注、极致的服务理念,为客户提供成都网站设计、成都做网站 网站设计制作按需策划设计,公司网站建设,企业网站建设,成都品牌网站建设,全网营销推广,外贸营销网站建设,大兴安岭网站建设费用合理。

Step1. 创建一张表,其中shape用来存放空间数据

 
 
 
  1. CREATE TABLE mylake (  
  2. feature_id NUMBER PRIMARY KEY,  
  3. name VARCHAR2(32),  
  4. shape MDSYS.SDO_GEOMETRY); 

Step2. 在user_sdo_geom_metadata 表中插入新记录,用于描述空间字段

 
 
 
  1. INSERT INTO user_sdo_geom_metadata VALUES (  
  2. 'mylake',    //---表名  
  3.     'shape',    //---字段名  
  4.     MDSYS.SDO_DIM_ARRAY(     
  5. MDSYS.SDO_DIM_ELEMENT('X', 0, 100, 0.05),    //---X维最小,***值和容忍度。  
  6.         MDSYS.SDO_DIM_ELEMENT('Y', 0, 100, 0.05)    //---Y维最小,***值和容忍度 NULL    //---坐标系,缺省为笛卡尔坐标系  
  7. ); 

Step3. 创建空间索引

 
 
 
  1. CREATE INDEX mylake_idx ON mylake(shape)   
  2. INDEXTYPE IS MDSYS.SPATIAL_INDEX 

Step4. 插入空间数据

Oracle Spatial用MDSYS.SDO_GEOMETRY来存储空间数据,定义为:

 
 
 
  1. CREATE TYPE sdo_geometry AS OBJECT (  
  2. SDO_GTYPE NUMBER,  
  3. SDO_SRID NUMBER,  
  4. SDO_POINT SDO_POINT_TYPE,  
  5. SDO_ELEM_INFO MDSYS.SDO_ELEM_INFO_ARRAY,  
  6. SDO_ORDINATES MDSYS.SDO_ORDINATE_ARRAY); 

SDO_SRID:坐标系,NULL为笛卡尔坐标系。 SDO_POINT:Oracle Spatial也可定义单个的点,SDO_POINT的定义: CREATE TYPE sdo_point_type AS OBJECT (X NUMBER,Y NUMBER,Z NUMBER); 如果是二维,Z为NULL。 SDO_ELEM_INFO:每三个值描述一个元素。 ***个值:***个顶点在SDO_ORDINATES_ARR开始位置 。第二个值:元素类型 。第三个值:顶点连接方式:1-通过直线连接,2-通过圆弧连接:定义为CREATE TYPE sdo_elem_info_array AS VARRAY (1048576) of NUMBER; SDO_ORDINATES:几何图形所有顶点列表。定义为    为CREATE TYPE sdo_ordinate_array AS VARRAY (1048576) of NUMBER;

// 插入包含一个岛屿的湖泊

 
 
 
  1. INSERT INTO mylake VALUES(  
  2. 10,   
  3. 'Lake Calhoun',   
  4. MDSYS.SDO_GEOMETRY(  
  5. 2003,  
  6. NULL,  
  7. NULL,  
  8. MDSYS.SDO_ELEM_INFO_ARRAY(1,1003,1, 19,2003,1),  
  9. MDSYS.SDO_ORDINATE_ARRAY(0,0, 10,0, 10,10, 0,10, 0,0, 4,4, 6,4, 6,6, 4,6, 4,4)  
  10. )); 

// 插入两艘小船

 
 
 
  1. INSERT INTO mylake VALUES(  
  2. 11,   
  3. 'The Windswept',   
  4. MDSYS.SDO_GEOMETRY(  
  5. 2003,  
  6. NULL,  
  7. NULL,  
  8. MDSYS.SDO_ELEM_INFO_ARRAY(1,1003,1),  
  9. MDSYS.SDO_ORDINATE_ARRAY(2,2, 3,2, 3,2, 2,3, 2,2) ); INSERT INTO mylake VALUES(  
  10. 12,   
  11. 'Blue Crest',   
  12. MDSYS.SDO_GEOMETRY(  
  13. 2003,  
  14. NULL,  
  15. NULL,  
  16. MDSYS.SDO_ELEM_INFO_ARRAY(1,1003,1),  
  17. MDSYS.SDO_ORDINATE_ARRAY(7,7, 8,7, 8,7, 7,8, 7,7) ); 

Step4. 查询Oracle Spatial查询数据包括二个处理过程:1.只通过索引查询候选项。通过函数SDO_FILTER实现:SDO_FILTER(geometry1 MDSYS.SDO_GEOMETRY, geometry2 MDSYS.SDO_GEOMETRY, params VARCHAR2) geometry1: 必须是被索引的几何数据 geometry2:不一定是表中的空间字段,也不要求被索引 params:Filter类型         querytype=WINDOW:geometry2不要求来自表 querytype=JOIN:geometry2必须来自表。

 
 
 
  1. SELECT name boat_name  
  2. FROM mylake t  
  3. WHERE feature_id = 12 
  4. AND SDO_FILTER(t.shape, mdsys.sdo_geometry(2003,NULL,NULL,  
  5. mdsys.sdo_elem_info_array(1,1003,1),  
  6. mdsys.sdo_ordinate_array(2,2, 5,2, 5,5, 2,5, 2,2)),'querytype=WINDOW') = 'TRUE';  

// 选择在定义矩形内的所有小船

 
 
 
  1. SELECT name boat_name  
  2. FROM mylake t  
  3. WHERE feature_id = 12 
  4. AND SDO_FILTER(t.shape, mdsys.sdo_geometry(2003,NULL,NULL,  
  5. mdsys.sdo_elem_info_array(1,1003,1),  
  6. mdsys.sdo_ordinate_array(2,2, 5,2, 5,5, 2,5, 2,2)),  
  7. 'querytype=WINDOW') = 'TRUE'  
  8. AND SDO_RELATE(t.shape, mdsys.sdo_geometry(2003,NULL,NULL,  
  9. mdsys.sdo_elem_info_array(1,1003,1),  
  10. mdsys.sdo_ordinate_array(2,2, 5,2, 5,5, 2,5, 2,2)),  
  11. 'masktype=INSIDE querytype=WINDOW') = 'TRUE' 

// masktype可联合使用

 
 
 
  1. SELECT feature_id id  
  2. FROM mylake t  
  3. WHERE feature_id = 12 
  4. AND SDO_FILTER(t.shape, mdsys.sdo_geometry(2003,NULL,NULL,  
  5. mdsys.sdo_elem_info_array(1,1003,1),  
  6. mdsys.sdo_ordinate_array(2,2, 5,2, 5,5, 2,5, 2,2)),  
  7. 'querytype=WINDOW') = 'TRUE'  
  8. AND SDO_RELATE(t.shape, mdsys.sdo_geometry(2003,NULL,NULL,  
  9. mdsys.sdo_elem_info_array(1,1003,1),  
  10. mdsys.sdo_ordinate_array(2,2, 5,2, 5,5, 2,5, 2,2)),  
  11. 'masktype=INSIDE+TOUCH querytype=WINDOW') = 'TRUE' 

关于Oracle Spatial建表学习的相关知识就介绍到这里了,希望本次的介绍能够对您有所收获!

【编辑推荐】

  1. Star Schema的设计思路与总结
  2. MySQL性能分析及explain的使用
  3. Oracle数据库悲观锁与乐观锁详解
  4. SQL Server多表查询优化方案总结
  5. Oracle执行计划不走索引的原因总结

本文标题:Oracle Spatial建表学习步骤详解
URL链接:http://www.shufengxianlan.com/qtweb/news14/517214.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联