简析将shp导入Oracle并利用geoserver将导入的数据发布 - Naa

标签: shp oracle 利用 | 发表时间:2015-01-02 23:56 | 作者:Naa
出处:

1.环境准备

1.1 软件准备

首先要安装有支持空间数据的Oracle,其次有安装版或免安装版的geoserver,两者都部署好后,我们将开始讨论进一步需要配置的环境。

这里我使用由Oracle提供的shp2sdo来进行shp导入,同时使用由geoserver提供的可以连接Oracle数据源的插件来进行数据的发布。

Shp2sdo的下载地址为: http://down.51cto.com/data/223757

Geoserver的Oracle插件下载地址为:http://sourceforge.net/projects/geoserver/files/GeoServer。选择与你的geoserver版本对应的插件版本进行下载,比如我的是:geoserver-2.2-oracle-plugin.zip。

1.2运行环境准备

1.2.1 数据库环境配置

将shp2sdo.exe拷贝至Oracle环境变量所指的目录(bin)下。比如我的是在:

                       

1.2.2 geoserver环境配置

将geoserver-2.2-oracle-plugin.zip解压后可得如下文件:

 

a.如果是安装版,将gt-jdbc-oracle.jar放入:[GEOSERVER_HOME]/server/geoserver/WEB-INF/lib;如果是免安装版,将gt-jdbc-oracle.jar放入:In a war install this is [container]/webapps/geoserver/WEB-INF/lib

b.如果是安装版,将ojdbc.jar放入:[GEOSERVER_HOME]/lib;我本人的是放入:F:\tomcat4Geoserver\lib。如果此文件放入的路径不对,oracle将无法连接上。

2.将shp导入Oracle

2.1 具体步骤

2.1.1命令行指向要导入的shp文件

2.1.2利用shp2sdo将shp转换为导入文件

2.1.2.1 命令行

先给出输入的命令行:shp2sdo commhjt commhjttest –i id –s 4326 –g GEOMETRY –d

2.1.2.2具体解析

-i id_colum指定id序列列,默认是id,即作为生成数据的唯一性标志;      

-s 指定生成srid(即采用什么坐标),默认是null(虽默认为null,导入后值是0,因此要注意将插入的元数据表的该条记录的srid更新为null,否则0值在MDSYS.CS_SRS表中没有记录,在后面会出错); 这里我的shp是WGS84坐标,所以直接写成4326。     

 -g  geometry column指定sdo_geometry,默认是GEOM;      

 -d 代表含义是将分解后的 ctl文件(控制文件)和data文件(数据存储文件)合并到一个文件,数据存储和控制都在ctl一个文件中。如果没有该选项,则会有单独的data文件生成,即ctl文件(控制文件)和data文件(数据存储文件);

以上命令行在shp文件夹中生成了如下文件:

 

打开commhjttest.sql可以看到其是一个创建shp表即相关空间元数据的sql:

 

打开commhjttest.ctl,可以发现数据的插入都在其中:

 

2.1.3创建对应shp表并注册到USER_SDO_GEOM_METADATA(利用commhjttest.sql)

首先登陆到数据库中 :sqlplus dlgis/dlgis@stdcg

然后输入:

SQL>@G:\shptest\commhjttest.sql  --创建表并注册到USER_SDO_GEOM_METADATA

SQL>quit --退出数据库

 

2.1.4通过sqlldr将数据导入到创建的表中(利用commhjttest.ctl)

sqlldr dlgis/dlgis@stdcg commhjttest --导入数据 (sqlldr即sql loader工具)

 

2.1.5将数据升级到与Oracle对应的版本上

首先再次连接到数据库上,然后输入:

SQL> execute sdo_migrate.to_current('commhjttest');

 

2.1.6为提高查询速度,添加空间索引

SQL>CREATE INDEX INDEX_OPER_DATA_SPATIAL ON commhjttest(GEOMETRY) INDEXTYPE IS MDSYS.SPATIAL_INDEX PARAMETERS('LAYER_GTYPE=POLYGON') NOPARALLEL;

 

如果出现以上现象,说明该索引名称可能之前就已经有使用,换一个名称即可,如索引名更换为:INDEX_OPER_DATA_SPATIAL_COMM

 

2.1.7    查看导入结果

 

2.2注意

当我们用shp2sdo生成shp的导入数据时,如果写的语句是:

 

即将空间参考默认为null时,最后生成索引时会报错,错误如下:

 

原因是此时的元数据表USER_SDO_GEOM_METADATA中的SRID是0而不是null。当我们将此SRID变为null后,再生成索引即可成功。

 

3.通过geoserver发布Oracle中的数据

3.1 建立基于Oracle数据源的Store

进入geoserver的web页面,点击stores,选择ORACLE NG:

 

 点击保存即可。

3.2 发布数据

 

选择要发布的数据,点击publish,做相关配置即可:

 

 

3.3浏览发布的图层服务

 

4.探讨

虽然用Oracle提供的shp2sdo工具可以将shp数据导入,但是目前就我的操作来说,还相对复杂,培训工程人员有一定的难度。如果想广泛的推广的话,应该要写一个相关的导入工具才行。

谢谢博友其心塞渊的提醒,让我知道了还有shp2sdo这样的工具可以使用,再次感谢。

 

                                                                          ——欢迎转载,但保留版权,请于明显处标明出处: http://www.cnblogs.com/naaoveGIS/


本文链接: 简析将shp导入Oracle并利用geoserver将导入的数据发布,转载请注明。

相关 [shp oracle 利用] 推荐:

简析将shp导入Oracle并利用geoserver将导入的数据发布 - Naa

- - 博客园_首页
首先要安装有支持空间数据的Oracle,其次有安装版或免安装版的geoserver,两者都部署好后,我们将开始讨论进一步需要配置的环境. 这里我使用由Oracle提供的shp2sdo来进行shp导入,同时使用由geoserver提供的可以连接Oracle数据源的插件来进行数据的发布. Shp2sdo的下载地址为: http://down.51cto.com/data/223757.

geoserver发布shp

- - 开源软件 - ITeye博客
Geoserver 发布图层. Geoserver除了浏览以外,其他譬如发布、删除等等操作均需要用户登陆,默认的账号和密码为:admin , geoserver .. 登陆后的首页应该是这样的:. 发布一个layer正确的顺序为:datastore(数据存储)->layer(图层). 需要先创建数据源,然后再从数据源中选择数据发布图层.

World Wind Java开发之五——读取本地shp文件

- - CSDN博客研发管理推荐文章
World Wind Java 使用IconLayer图层类表现点和多点数据,使用RenderableLayer图层表现线和面数据,一个图层只能对应一组shape文件. World Wind Java首先使用ShapefileLoader类完成对shape文件的读取和加载,再通过createLayerFromSource方法创建RenderableLayer,最后将创建的Layer加在layers上.

[Oracle] 利用自治事务实现审计功能

- - CSDN博客数据库推荐文章
在一个事务(外层事务)中可以定义一个或几个自治事务. 自治事务可以独立commit,不对外层事务产生影响,同样外层事务的 rollback 也对自治事务没有影响. 假设现在有这样一个需求,不能对某个表进行某些操作(如更新),一旦有这类操作,就强制整个回滚,并且在审计日志中记录该次违规操作. 现在的问题是当事务回滚之后,日志中的记录也会跟着被回滚,这时就可以利用自治事务来防止这个问题.

利用ogg实现oracle到kafka的增量数据实时同步 | 伦少的博客

- -
ogg即Oracle GoldenGate是Oracle的同步工具,本文讲如何配置ogg以实现Oracle数据库增量数据实时同步到kafka中,其中同步消息格式为json. 下面是我的源端和目标端的一些配置信息:. 注意:源端和目标端的文件不一样,目标端需要下载Oracle GoldenGate for Big Data,源端需要下载Oracle GoldenGate for Oracle具体下载方法见最后的附录截图.

Oracle 收购 Ksplice

- feng823 - LinuxTOY
实现无需重启即可为 Linux 内核打安全补丁的 Ksplice 被 Oracle 收购. 在被收购前, Ksplice 为 Fedora, Ubuntu 免费提供该功能,对于 RHEL 和 CentOS 则需要订阅其产品. Oracle 表示将把 Ksplice 带来的零宕机安全更新功能添加到 Oracle 产品订阅服务中,同时停止对其他企业级 Linux 发行版的支持,将 Oracle Unbreakable Linux 打造成唯一具备零宕机安全更新功能的企业级 Linux 发行版.

Linux Ksplice,MySQL and Oracle

- Syn - DBA Notes
Oracle 在 7 月份收购了 Ksplice. 使用了 Ksplice 的 Linux 系统,为 Kernel 打补丁无需重启动,做系统维护的朋友应该明白这是一个杀手级特性. 现在该产品已经合并到 Oracle Linux 中. 目前已经有超过 700 家客户,超过 10 万套系统使用了 Ksplice (不知道国内是否已经有用户了.

oracle license计算

- Fenng - eagle's home
Oracle license的计算是基于CPU core的. 用core的数目乘以一个系数core factor就可以得到所需的oracle license的数目. 对于不同的CPU,core factor是不一样的,可以从oracle提供的这张列表中查到 Oracle Processor Core Factor Table.

Oracle Exadata初探

- - 技术改变世界 创新驱动中国 - 《程序员》官网
在我们看来,它是一个把硬件和软件根据合理的配置整合在一起的 Oracle数据库(在本文编写时是11gR2版本)平台. Exadata数据库机器包含了存储子系统,在存储层上运行着研发的新软件,这使得研发人员可以做一些在其他平台上无法完成的事情. 实际上,Exadata一开始是以一个存储系统形式诞生的,如果你跟参与研发此产品的人交谈,你经常会听到他们称存储组件为Exadata或者是SAGE (Storage Appliance for Grid Environments,网格环境存储设备),这是该产品研发项目的代码名称.

Oracle MySQL Or NoSQL续

- - Sky.Jian 朝阳的天空
接前面一篇,这里再将之前在“中国系统架构师大会”5周年的时候发布的纪念册“IT架构实录”上的一篇文章发出来,也算是前面博文中PPT的一个文字版解读吧. Oracle,MySQL 还是 NoSQL. 随着阿里系的“去IOE”运动在社区的宣传声越来越大,国内正在掀起一股“去xxx”的技术潮. 不仅仅是互联网企业,包括运营商以及金融机构都已经开始加入到这个潮流之中.