zoukankan      html  css  js  c++  java
  • 简析将shp导入Oracle并利用geoserver将导入的数据发布

    文章版权由作者李晓晖和博客园共有,若转载请于明显处标明出处:http://www.cnblogs.com/naaoveGIS/

    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: omcat4Geoserverlib。如果此文件放入的路径不对,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:shptestcommhjttest.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/

                                                                               如果您觉得本文确实帮助了您,可以微信扫一扫,进行小额的打赏和鼓励,谢谢 ^_^

                                          

  • 相关阅读:
    根据现有文件生成图形化的目录树
    一个最简的短信验证码倒计时例子
    将指定目录下的所有资源整体迁移到另一个目录下
    通过 url 获取相应的 location 信息
    node-glob的*匹配
    mysql将查询出来的一列数据拼装成一个字符串
    Call to undefined function mysql_connect()错误原因
    JavaScript转unix时间戳
    .net3.0 中跨线程访问控件
    WPF的线程模型
  • 原文地址:https://www.cnblogs.com/naaoveGIS/p/4199006.html
Copyright © 2011-2022 走看看