Oracle_spatial的空间索引
空间索引
1、空间索引的创建
1)创建索引之前总是要为空间层插入元数据
2)如果之前创建的索引失败了,必须先删除才能创建
Drop index customers_sidx;
创建索引:
Create index customers_sidx on customers(location)
Indextype is mdsys.spatial_index
在索引创建过程中,Oracle检查索引列的sdo_srid和user_sdo_geom_metadata中的srid是否匹配,如果不匹配,Oracle会产生ora-13365错误。
空间索引信息可查看user_sdo_index_metadata或者较简单的user_sdo_index_info视图。
空间索引表存储在这个SDO_INDEX_TABLE字段中,总是以MDRT开头。不能将一个空间索引表和普通的表一样对待-即不能将它从一个表空间移到另一个表空间,也不能将它删除、复制等。否则,会出现无效的空间索引并导致后续的空间查询操作符或空间索引重建失败。
2、空间索引的参数
create INDEX <INDEX_NAME> ON <TABLE_NAME>(<COLUMNNAME>)
INDEXTYPE IS MDSYS.SPATIAL_INDEX
PARAMETERS('PARAMETER_STRING');
1)TABLESPACE参数
通过该参数,可以指定哪个表空间来存储空间索引表。除了TABLESPACE参数外,还可以指定另外两个参数INITIAL和NEXT
create index cola_markets_spatial_geo_idx on cola_markets(LOCATION)
indextype is mdsys.spatial_index
parameters ('TABLESPACE=gmapdata next=5 INITIAL=10k');
如果表空间是本地管理的,那么INITIAL和NEXT参数就是多余的,即即使指定了他们,Oracle也会忽略它们。
注:表空间是否是本地管理的,可以通过user_tablespaces视图的segment_space_management字段是否为auto来验证。
2)work_tablespace参数
在索引创建过程中,R-tree索引会在整个的数据集上执行排序操作,因此会产生一些工作表。不过这些工作表在索引创建过程结束时会被删除。创建和删除大量不同大小的表会使表空间产生很多碎片。为避免这种情况,可以通过使用work_tablespace参数来为这些工作表指定一个单独的表空间。
create index cola_markets_spatial_geo_idx on cola_markets(LOCATION)
indextype is mdsys.spatial_index
parameters ('work_tablespace=gmapdata');
指定了工作表空间后,索引和数据就不会再索引创建过程中产生碎片。如果没有指定工作表空间,则默认工作表和索引被创建在同一个表空间。
3)layer_gtype
该参数指定了索引列的几何数据为特定类型几何体。这有助于完整性检查,有时还可加快查询操作符的执行速度。
create index cola_markets_spatial_geo_idx on cola_markets(LOCATION)
indextype is mdsys.spatial_index
parameters ('layer_gtype =point');
4)sdo_index_dims参数
该参数指定了空间索引的维数,默认为2.
create index cola_markets_spatial_geo_idx on cola_markets(LOCATION)
indextype is mdsys.spatial_index
parameters ('sdo_index_dims=3');
5)sdo_dml_batch_size参数
该参数用于指定一个事务中批量插入/删除/更新时得批量大小(对有大量插入的事务,该参数应设为5000或10000)。默认为1000.
create index cola_markets_spatial_geo_idx on cola_markets(LOCATION)
indextype is mdsys.spatial_index
parameters ('sdo_dml_batch_size=5000');
注:如果预计会对一个含有空间索引的表执行含有大量插入(或删除、更新)操作的事务,就应在create index语句或随后的alter_index rebuild语句中将sdo_dml_batch_size的值设为5000或10000.
6)sdo_level参数
指定sdo_level参数的值来创建一个四叉树索引。四叉树需要显式地进行性能调优,因此不被推荐使用。
create index cola_markets_spatial_geo_idx on cola_markets(LOCATION)
indextype is mdsys.spatial_index
parameters ('sdo_level=8');
3、空间索引视图
user_sdo_index_metadata和user_sdo_index_info(后一个较简单)
可以从user_sdo_index_metadata视图中查看索引设置的参数。
对于一张表中n行数据的一个集合,R-tree空间索引大致需要100*3*N字节作为空间索引表的存储空间。另外,在创建索引的过程中,r-tree索引还需要额外200*3*N到300*3*N字节作为临时工作表的存储空间。
--查看表索引大小
select sdo_tune.estimate_rtree_index_size('GWM', 'COLA_MARKETS', 'SHAPE') sz FROM dual;
SDO_TUNE.ESTIMATE_RTREE_INDEX_SIZE(
schemaname IN VARCHAR2,
tabname IN VARCHAR2,
colname IN VARCHAR2,
partname IN VARCHAR2 DEFAULT NULL
) RETURN NUMBER;
or
SDO_TUNE.ESTIMATE_RTREE_INDEX_SIZE(
number_of_geoms IN INTEGER,
db_block_size IN INTEGER,
sdo_rtr_pctfree IN INTEGER DEFAULT 10,
num_dimensions IN INTEGER DEFAULT 2,
is_geodetic IN INTEGER DEFAULT 0
) RETURN NUMBER;
4、基于函数的空间索引
create or replace function gcdr_geometry(street_number varchar2,
street_name varchar2,
city varchar2,
state varchar2,
postal_code varchar2)
return mdsys.sdo_geometry deterministic is
begin
return(sdo_gcdr.geocode_as_geometry('SPATIAL',
sdo_keywordarray(street_number || ' ' ||
street_name,
city || ' ' || state || ' ' ||
postal_code),
'US'));
end;
create index cola_markets_spatial_geo_idx on cola_markets
(
gcdr_geometry(street_number,street_name,city,state,postal_code)
)
indextype is mdsys.spatial_index
parameters ('LAYER_GTYPE=POINT');
如果在一个地理编码地址到sdo_geometry对象的函数上创建空间索引,就应该在create index语句中指定参数'LAYER_GTYPE=POINT'。如果不指定该参数,查询速度会很慢。
5、本地分区空间索引
在分区表上创建本地索引
分区表创建本地索引的条件:
只能在range_partitioned表上创建本地空间索引,而不能在list-或hash-partitioned表上创建空间索引。
本地空间索引相对于创建一个全局索引的优点:
易管理性:重建指定分区上的本地索引不会影响其他分区。
易伸缩性:为提高性能,可只在指定分区上进行查询,空间索引可在每个分区上并行创建。
create index cola_markets_spatial_geo_idx on cola_markets(LOCATION)
indextype is mdsys.spatial_index
parameters ('TABLESPACE=gmapdata')
local
(
Partition ip1 parameters ('TABLESPACE=gmapdata'),
Partition ip2,
Partition ip3
);
6、并行索引
语法:
create index cola_markets_spatial_geo_idx on cola_markets(LOCATION)
indextype is mdsys.spatial_index
parameters【parallel_degree】;
--创建并行索引
create index cola_markets_spatial_geo_idx on cola_markets(LOCATION)
indextype is mdsys.spatial_index
parameters parallel;
--修改为并行索引
Alter table cola_markets parallel 2;
不管创建的索引是一个本地分区索引还是一个全局索引,如果parallel degree大于2,则索引的创建就会并行执行。
7、在线重建索引
当对一个含有空间索引的表进行大量(典型值为30%)删除操作后,对相关空间索引进行重建将使得该索引相对紧凑,从而可以更有效地服务随后的查询。
Alter index cola_markets_spatial_geo_idx rebuild;
--也可以指定参数
Alter index cola_markets_spatial_geo_idx rebuild parameters ('layer_gtype =point');
Alter index是一个DDL语句,Alter index…rebuild是个阻塞语句。因此如果在索引上有任何一个并发执行的DML(可能在不同的会话中),那么该命令将被阻塞直到它获得索引上的互斥锁。同理,在重建开始后,任何一个在表或索引上并发执行的DML语句都会被阻塞。所以为保证查询在索引重建时不被阻塞,可在Alter index…rebuild语句中指定关键词ONLINE。
Alter index cola_markets_spatial_geo_idx rebuild online parameters ('layer_gtype =point');
Oracle_spatial的空间索引的更多相关文章
- Oracle_spatial的函数介绍[转]
Oracle_spatial的函数 一sdo_Geom包的函数: 用于表示两个几何对象的关系(结果为True/False)的函数:RELATE,WITHIN_DISTANCE 验证的函数:VALIDA ...
- Oracle_spatial的函数介绍
Oracle_spatial的函数 一sdo_Geom包的函数: 用于表示两个几何对象的关系(结果为True/False)的函数:RELATE,WITHIN_DISTANCE 验证的函数:VALIDA ...
- MongoDB-JAVA-Driver 3.2版本常用代码全整理(4) - 地理空间索引
MongoDB的3.x版本Java驱动相对2.x做了全新的设计,类库和使用方法上有很大区别.例如用Document替换BasicDBObject.通过Builders类构建Bson替代直接输入$命令等 ...
- R树空间索引
R树在数据库等领域做出的功绩是非常显著的.它很好的解决了在高维空间搜索等问题.举个R树在现实领域中能够解决的例子吧:查找20英里以内所有的餐厅.如果没有R树你会怎么解决?一般情况下我们会把餐厅的坐标( ...
- 在oracle中创建空间索引
Oracle spatial可以方便的存储空间数据,大量的空间数据必需要使用空间索引去查询.在oracle中创建空间索引必需先建立元数据,否则无法创建索引.创建元数据的代码: insert into ...
- Mongodb地理空间索引
1.索引: 建立索引既耗时也费力,还需要消耗很多资源.使用{"bakckground":true}选项可以使这个过程在后台完成,同时正常处理请求.如果不包括background 这 ...
- MongoDB的地埋空间数据存储、空间索引以及空间查询
一.关于MongoDB 在众多NoSQL数据库,MongoDB是一个优秀的产品.其官方介绍如下: MongoDB (from "humongous") is a scalable, ...
- mongodb的地理空间索引常见的问题
创建地理空间索引注意事项 创建地理空间索引失败,提示错误信息如下 > db.places.ensureIndex({"loc":"2dsphere"}){ ...
- mysql对GIS空间数据的支持,包括创建空间索引
CREATE TABLE tb_geo( id INT PRIMARY KEY AUTO_INCREMENT, NAME ) NOT NULL, pnt POINT NOT NULL, SPATIAL ...
随机推荐
- Spring Security认证配置(二)
学习本章之前,可以先了解下上篇Spring Security基本配置. 本篇想要达到这样几个目的: 1.访问调用者服务时,如果是html请求,则跳转到登录页,否则返回401状态码和错误信息 2.调用方 ...
- Linux下安装SQL Server 2016(安装篇SQL Server on linux)
安装过程 如何安装直接参考这个文章:安装sql server 整个安装过程非常简单. 上面的文档里是通过 sudo 命令,用root身份来执行,不过这里为了简单,就用root账号来安装的. (1)下载 ...
- C# 集合 特殊集合
一集合 1.可为不同类型,不固定长度 2.集合类型分为泛型集合(强类型集合)与非泛型集合(弱类型集合). 3.非泛型集合的类和接口位于using System.Collections命名空间. 4.泛 ...
- [android] WebView与Js交互
获取WebView对象 调用WebView对象的getSettings()方法,获取WebSettings对象 调用WebSettings对象的setJavaScriptEnabled()方法,设置j ...
- Web前端基础——HTML
一 .HTML 概述 HTML : 超文本标记语言 HyperText markup language <marquee behavior="alternate"> & ...
- SpringBoot -- 计划任务
从Spring 3.1 开始,计划任务在Spring中的实现变得异常的简单.首先通过在配置类注解@EnableScheduling 来开启对计划任务的支持,然后再执行集合任务的方法上注解@Schedu ...
- CentOS7部署Django项目
1. 云服务器 这里使用的是腾讯云选择系统:CentOS7.3 记住云服务器登录密码 2. 配置Python3环境 默认Python环境为python2.7,yum安装是需要python2的环境的 安 ...
- xxl-job 实现高可用
xxl-job-Admin是一个服务调度中心,管理所有的任务的触发. 1.如果xxl-job-Admin平台如果宕机了,该如何处理? 需要搭建集群. 2.xxl-job-Admin 如何搭建集群? 使 ...
- amazeui+canvas绘制二维码
<link rel="stylesheet" type="text/css" href="css/amazeui.min.css"/& ...
- phpstudy集成下Apache配置部署https安全证书
一..先申请到安全证书.(腾讯云或者阿里云申请免费1年的安全证书),怎么申请这里也说下(以腾讯云为例): 1.登录腾讯云QQ或微信登录都行,第一次登录要通过实名认证,点击[产品]---[ss证书l] ...