shp转oracle spatial
2010年12月1日 ![]()
终于搞定了shp到oracle spatial,说下步骤和感受吧!
1 XP系统:转换工具的下载(shp2sdo.exe );下载后把此文件复制到PATH变量包含的目录下(E:\oracle\product\10.2.0\db_1\BIN)
unix系统:ftp ip 回车;输入用户名密码;cd /oracle/product/10.2.0/db_1/bin;put 直接将本机文件拖到命令窗口 回车
2 将要转的shp文件放到某个目录下(F:\SHP_DATA)
3 在dos下执行以下命令
C:\Documents and Settings\administrator>cd f:\shp_data
C:\Documents and Settings\administrator>f:
F:\SHP_DATA> 转入放置shp数据的目录
F:\SHP_DATA>shp2sdo shp_data oper_data -i id -s null -g GEOMETRY -d
运行完该命令后自动生成了
oper_data.sql和oper_data.ctl
备注:
-i id_colum指定id序列列,默认是id,即作为生成数据的唯一性标志;
-s 指定生成srid(即采用什么坐标),默认是null(虽默认为null,导入后值是0,因此要注意将插入的元数据表的该条记录的srid更新为null,否则0值在MDSYS.CS_SRS表中没有记录,在后面会出错);
-g geometry column指定sdo_geometry,默认是GEOM;
-d 代表含义是将分解后的 ctl文件(控制文件)和data文件(数据存储文件)合并到一个文件,数据存储和控制都在ctl一个文件中,
如果没有该选项,则会有单独的data文件生成,即ctl文件(控制文件)和data文件(数据存储文件);
4 F:\SHP_DATA>sqlplus dd/xxx@oracl --登陆数据库
SQL> @F:\SHP_DATA\oper_data.sql --创建表并注册到USER_SDO_GEOM_METADATA
SQL> quit --退出数据库
5 F:\SHP_DATA>sqlldr dd/xxx@oracl oper_data --导入数据 (sqlldr即sql loader工具)
6 然后升级数据到当前oracle版本:对polygon类型是必须的
SQL> execute sdo_migrate.to_current('oper_data');
7 创建空间索引 注意oper_data该记录在USER_SDO_GEOM_METADATA表中的srid为null
UPDATE OPER_DATA a SET a.geom.SDO_SRID =NULL;
UPDATE USER_SDO_GEOM_METADATA SET SRID = NULL where table_name='OPER_DATA';
CREATE INDEX INDEX_OPER_DATA_SPATIAL ON OPER_DATA(GEOMETRY)INDEXTYPE IS MDSYS.SPATIAL_INDEX PARAMETERS('LAYER_GTYPE=POLYGON') NOPARALLEL;
中间出现的一些问题:
1、第一次导后,我想创建空间索引,但是却提示:ora-29879:使用同一个索引类型无法再列表上创建多个域索引
一查原来该表的geom字段已经有了空间索引(以为是导入数据后自动创建了空间索引,但是我第二次转的时候却可以成功创建空间索引,不知何故)
2、在shp转oracle spatial的时候,在该命令中 F:\SHP_DATA>shp2sdo shp_data oper_data -i id -s null -g GEOMETRY -d 我设-s为null,是不是null默认是0?所以创建空间索引的时候会提示srid为0的在MDSYS.CS_SRS表srid没有0值;而更新oper_data这个表的任何字段都出现错误:ora-29861:域索引标记为loading/failed/unusab
做如下更新后UPDATE USER_SDO_GEOM_METADATA SET SRID = NULL where table_name='OPER_DATA'; 空间索引和表都可以更新了。
原因分析:导致OPER_DATA该表无法更新是因为该表的空间索引创建的问题,因为在最开始shp转oraclespatial的时候,对于srid值(坐标系统值,因为上海的坐标系统比较特殊,所以我就将该值设为null)设为了null,而null在数据库里面默认为了0,而0值在MDSYS.CS_SRS表又没有这个定义,所以导致了这样的错误
因此如果想设srid为0,那么直接不要指定-s参数,这样就会默认为空,如果指定了-s null那么数据库会默认为srid为0.
shp转oracle spatial的更多相关文章
- Oracle Spatial导入shp数据
现在开始尝试用oracle spatial管理空间数据,刚学会shp数据的导入,总结如下.oracle11g安装后,已经有了oracle spatial组件,我们只需要用shp2sdo.exe工具,就 ...
- 简析将shp导入Oracle并利用geoserver将导入的数据发布
文章版权由作者李晓晖和博客园共有,若转载请于明显处标明出处:http://www.cnblogs.com/naaoveGIS/. 1.环境准备 1.1 软件准备 首先要安装有支持空间数据的Oracle ...
- Oracle Spatial中SDO_Geometry详细说明[转]
在ArcGIS中通过SDE存储空间数据到Oracle中有多种存储方式,分别有:二进制Long Raw .ESRI的ST_Geometry以及基于Oracle Spatial的SDO_Geometry等 ...
- Oracle Spatial中SDO_Geometry说明
Oracle Spatial中SDO_Geometry说明 在ArcGIS中通过SDE存储空间数据到Oracle中有多种存储方式,分别有:二进制Long Raw .ESRI的ST_Geometry以及 ...
- Oracle Spatial操作geometry方法
Oracle Spatial中SDO_GEOMETRY类型: CREATE TYPE SDO_GEOMETRY AS OBJECT( SDO_GTYPE NUMBER,--几何类型,如点线面 SDO_ ...
- Oracle spatial抽稀函数(SDO_UTIL.SIMPLIFY)
在使用Oracle spatial做空间查询和展示时,经常会遇到展示或者查询过慢,这时候我可以通过空间数据抽稀来优化查询展示效率. 在Oracle spatial中的抽稀函数为:SDO_UTIL.SI ...
- Oracle spatial 空间修正函数(SDO_UTIL.RECTIFY_GEOMETRY)
Oracle spatial有个空间修正函数SDO_UTIL.RECTIFY_GEOMETRY,它可以修复以下可能:a.重复节点 b.自相交 c.坐标串朝向不正确. 该函数的构造函数格式: SDO_U ...
- Oracle Spatial GIS相关研究
1.Oracle Spatial 概念相关 Oracle Spatial 是Oracle 数据库强大的核心特性,包含了用于存储矢量数据类型.栅格数据类型和持续拓扑数据类型的原生数据类型.Oracle ...
- C#读取Oracle Spatial的sdo_geometry
oracle的sdo_geometry中内置get_wkt和get_wkb两个方法. 以数据库表geoms为例,此表中有id和geometry两列 try { OracleConnection con ...
随机推荐
- PetaPoco源代码学习--3.Sql类
PetaPoco对数据库的操作直接使用SQL语句,在代码中进行调用既可以直接传递SQL语句,也可以使用提供的SQL类来获取到SQL语句进行操作,直接传递SQL语句在内部实现中也是封装成Sql类传递到底 ...
- asp.net core webapi 使用ef 对mysql进行增删改查,并生成Docker镜像构建容器运行
1.构建运行mysql容器,添加数据库user 参考Docker创建运行多个mysql容器,地址 http://www.cnblogs.com/heyangyi/p/9288402.html 添加us ...
- Netty的基本概念
异步 等待它的同时你也可以做点别的事情 阻塞I/O 只能同时处理一个连接,要管理多个并发客户端,需要为每个新的客户端Socket创建一个新的Thread 使用Selector的非阻塞I/O class ...
- JavaScript中=、==、===以及!=、!==的区别与联系
JavaScript中=.==.===以及!=.!==的区别与联系 在JavaScript中,“=”代表赋值操作:“==”先转换类型再比较,“===”先判断类型,如果不是同一类型直接为false. ...
- InfoQ观察:Java EE的未来
原创 2017-03-06 Charles Humble 聊聊架构 作者|Charles Humble编辑|薛命灯 作为InfoQ下一年编辑关注点审核工作的一部分,我们挑选了Java作为深入探讨的主题 ...
- OSGI企业应用开发(十二)OSGI Web应用开发(一)
前面文章中介绍了如何在OSGI应用中整合Spring和Mybatis框架,本篇文章开始介绍如何使用OSGI技术开发Web应用.对于传统的Java EE应用,应用中涉及到的Web元素无非就是Servle ...
- Linux 系统下用源码包安装软件
Linux系统下用源码包安装软件 by:授客 QQ:1033553122 下载源码安装包,解压或者直接双击打开(如果有安装zip或rar等压缩/解压缩软件的话),查找相关的安装说明文件,一般是READ ...
- SurfaceViewVideoList网络获取视频播放
主布局: <?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:andro ...
- 代码操作Word时,目录自动更新的两种方法
最近的项目中有一个功能点为:根据分析数据库并生成报告.不过不是大数据.数据挖掘之类,报告的内容.组织方式都是事先固定下来的.实现的方式为,在普通word文档中插入书签制成模板,然后程序使用OpenXM ...
- 数据分析——Matplotlib图形绘制
创建画布或子图 函数名称 函数作用 plt.figure 创建一个空白画布,可以指定画布大小,像素. figure.add_subplot 创建并选中子图,可以指定子图的行数,列数,与选中图片编号. ...