关于这个内容,其实从ArcSDE9.2推出ST_Geometry就让用户感到很有吸引力,而且特别是在ArcSDE9.3之后,用户使用SQL操作ST_geometry越来越多,但是在配置Oracle监听来说总是碰到这样那样的问题,以下就是总结一下配置 Oracle 侦听器来使用SQL操作ST_Geometry 。

首先说明一下:如果你的ArcSDE版本是9.2最好不要使用这种方式,因为Bug也是比较多的。

例如:http://support.esri.com/en/knowledgebase/techarticles/detail/33918

1:我们需要使用SQL操作ST_Geometry,那么我们的数据存储都应该以ST_Geometry,但是有一点容易被用户忽视的就是原来的数据可能是ArcSDE9.2他们都是以BLOB或者Long Raw进行存储,然后升级到ArcSDE9.3但是存储没有升级,这样怎么配置都不能SQL操作,这是往往被用户忽视的问题。

解决该问题:使用Migrate工具迁移一下存储。

2:查看一下Oracle的监听状态,extporc(CLRextproc)的状态必须为静态(Unknow),如果是Ready状态就有可能出现问题,而且Oracle监听必须同时监听TCP和IPC

  1. C:\Users\Administrator>lsnrctl status
  2. LSNRCTL for 64-bit Windows: Version 11.2.0.1.0 - Production on 26-12月-2011 10:2
  3. 9:44
  4. Copyright (c) 1991, 2010, Oracle.  All rights reserved.
  5. 正在连接到 (DESCRIPTION=(ADDRESS=(PROTOCOL=IPC)(KEY=EXTPROC1521)))
  6. LISTENER 的 STATUS
  7. ------------------------
  8. 别名                      LISTENER
  9. 版本                      TNSLSNR for 64-bit Windows: Version 11.2.0.1.0 - Produ
  10. ction
  11. 启动日期                  26-12月-2011 10:28:14
  12. 正常运行时间              0 天 0 小时 1 分 34 秒
  13. 跟踪级别                  off
  14. 安全性                    ON: Local OS Authentication
  15. SNMP                      OFF
  16. 监听程序参数文件          D:\app\Administrator\product\11.2.0\dbhome_1\network\a
  17. dmin\listener.ora
  18. 监听程序日志文件          d:\app\administrator\diag\tnslsnr\lish\listener\alert\
  19. log.xml
  20. 监听端点概要...
  21. (DESCRIPTION=(ADDRESS=(PROTOCOL=ipc)(PIPENAME=\\.\pipe\EXTPROC1521ipc)))
  22. (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=192.168.100.111)(PORT=1521)))
  23. 服务摘要..
  24. 服务 "CLRExtProc" 包含 1 个实例。
  25. 实例 "CLRExtProc", 状态 UNKNOWN, 包含此服务的 1 个处理程序...
  26. 服务 "orcl" 包含 2 个实例。
  27. 实例 "orcl", 状态 UNKNOWN, 包含此服务的 1 个处理程序...
  28. 实例 "orcl", 状态 READY, 包含此服务的 1 个处理程序...
  29. 服务 "orclXDB" 包含 1 个实例。
  30. 实例 "orcl", 状态 READY, 包含此服务的 1 个处理程序...
  31. 命令执行成功

3:如果是分布式安装情况下

a:比如服务器安装的64Bit的Oracle服务器端,ArcSDE机器安装的32Bit的软件,两者都是Windows操作系统

b:比如服务器安装的64Bit的Oracle服务器端,AIX操作系统,ArcSDE机器安装的32Bit的软件,Windows操作系统

那么这就需要根据服务器端的Oracle的位数以及所以的操作系统来定相关的dll或者so的位数,也就是说这个配置必须跟Oracle的服务器端打交道,我们根据服务器的操作系统和位数来定

解决:

a:在服务器端安装一个64Bit的ArcSDE软件即可,其实最主要的就是需要64Bit的相关dll

b:在服务器端安装一个64Bit的适用于AIX操作系统的ArcSDE软件,一样道理

4:引用相关的dll以Windows为例,不仅仅只有一个st_shapelib.dll,还包括pe.dll,sg.dll,所以在使用过程中需要注意是否这三个dll都存在,在非windows环境下更是如此,此外还需要注意对这三个文件的读写操作。

5:配置完毕,我们可以使用以下命令来检查

注意:这个是在sde用户下

  1. SQL> select * from user_libraries;
  2. LIBRARY_NAME
  3. ------------------------------
  4. FILE_SPEC
  5. ------------------------------------------------------------------------------
  6. --------------------
  7. D STATUS
  8. - -------
  9. ST_SHAPELIB
  10. C:\Program Files\ArcGIS\ArcSDE\ora11gexe\bin\st_shapelib.dll
  11. Y VALID

如果没有的话

  1. SQL> create or replace library ST_SHAPELIB
  2. 2  as 'D:\Oracle\product\11.2.0\dbhome_1\BIN\st_shapelib.dll';
  3. 3  /
  4. 库已创建。
  5. SQL> alter package sde.st_geometry_shapelib_pkg compile reuse settings;
  6. 程序包已变更。

6:其实配置来说,也就是对listener.ora和TNSName.ora文件的配置

listener.ora:文件主要对相关St_shapelib.dll的引用,用户也可以将我所讲到的三个dll拷贝到ORACLE_HOME/bin文件夹里面,注意相关的权限,然后EXTPROC_DLLS=ANY,这种方法也可以可以的。

  1. # listener.ora Network Configuration File: D:\app\Administrator\product\11.2.0\dbhome_1\network\admin\listener.ora
  2. # Generated by Oracle configuration tools.
  3. SID_LIST_LISTENER =
  4. (SID_LIST =
  5. (SID_DESC =
  6. (SID_NAME = CLRExtProc)
  7. (ORACLE_HOME = D:\app\Administrator\product\11.2.0\dbhome_1)
  8. (PROGRAM = extproc)
  9. (ENVS = "EXTPROC_DLLS=ANY")
  10. )
  11. (SID_DESC =
  12. (GLOBAL_DBANAME = orcl)
  13. (ORACLE_HOME = D:\app\Administrator\product\11.2.0\dbhome_1)
  14. (SID_NAME = orcl)
  15. )
  16. )
  17. LISTENER =
  18. (DESCRIPTION_LIST =
  19. (DESCRIPTION =
  20. (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1521))
  21. (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.100.111)(PORT = 1521))
  22. )
  23. )
  24. ADR_BASE_LISTENER = D:\app\Administrator

7:TNSName.ora文件来说就是两个文件都有KEY值,保证这两个文件的KEY值一致就可以了,还有就是以我的经验,安装最新版本的Oracle比如现在我机器的环境就是oracle 11.2.0.1,他的TNSNAME文件并不会出现EXTPROC_CONNECTION_DATA关键字,所以我们需要修改为这个关键字即可。

 
Esri也有关于Oracle11gR2相关配置ST_Geometry的文章:http://support.esri.com/en/knowledgebase/techarticles/detail/38043

  1. # tnsnames.ora Network Configuration File: D:\app\Administrator\product\11.2.0\dbhome_1\network\admin\tnsnames.ora
  2. # Generated by Oracle configuration tools.
  3. LISTENER_ORCL =
  4. (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.100.111)(PORT = 1521))
  5. EXTPROC_CONNECTION_DATA =
  6. (DESCRIPTION =
  7. (ADDRESS_LIST =
  8. (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1521))
  9. )
  10. (CONNECT_DATA =
  11. (SID = CLRExtProc)
  12. (PRESENTATION = RO)
  13. )
  14. )
  15. ORCL =
  16. (DESCRIPTION =
  17. (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.100.111)(PORT = 1521))
  18. (CONNECT_DATA =
  19. (SERVER = DEDICATED)
  20. (SERVICE_NAME = orcl)
  21. )
  22. )

如果环境跟我一致,也可以将这两个文件复制,将用户的相关参数进行修改即可。

相关参数参考
  1. <span style="font-size:13px;">SID_LIST_LISTENER
  2. 此标注是名为 LISTENER(默认侦听器名称)的侦听器要处理的 SID 列表的开头。
  3. SID_LIST 和 SID_DESC
  4. 标题 SID_LIST 下的 SID_DESC 条目用于定义服务。列表中的第一个?跄看? extproc 请求,第二个条目处理客户端会话。
  5. SID_NAME
  6. 其值必须与在文件 tnsnames.ora 中为 extproc 指定的 SID 对应。
  7. ORACLE_HOME
  8. 定义此项服务的 Oracle 主页的位置。从此位置下的文件夹加载 extproc 程序文件。
  9. PROGRAM
  10. 指定 extproc 可执行文件的文件名。此区分大小写的名称可能是 extproc 或 extproc.exe,具体取决于操作系统的类型。文件位于 ORACLE_HOME/bin。
  11. ENVS
  12. 这是 extproc 在运行时所使用的环境变量的列表。列表用冒号分隔。此列表必须包括环境变量 EXTPROC_DLLS 以及 extproc 在运行时需要的任何其他环境变量的定义,其他环境变量通常包括 UNIX 和 Linux 系统中的 LD_LIBRARY_PATH、SHLIB_PATH 或 LIBPATH,或者 Windows 服务器上的 PATH。路径变量通常包括几何与投影引擎库的位置。
  13. EXTPROC_DLLS
  14. 此环境变量用于定义 extproc 可直接从中加载和调用函数的库的列表。包含 ST_SHAPELIB 和 LIBST_RASTER 库的文件的路径必须在此指定。
  15. 对于安装在 UNIX 上的 Oracle 服务器,列表用冒号分隔,对于安装在 Windows 上的 Oracle 服务器,列表用分号分隔。所有路径都必须是绝对路径并且指向本地目录,或者是 Oracle 系统用户可访问的 UNC 路径。这也意味着如果已将 ArcSDE 安装在非 Oracle 服务器上,则必须将形状和栅格库复制到 Oracle 服务器。有关详细信息,请参阅在不同的服务器上安装 Oracle 和 ArcSDE。
  16. 不存在环境变量替换。
  17. 可选关键字 ANY 和 ONLY 可用于放宽或限制 extproc 使用库文件的方式。如果将 ANY 放在路径前面,Oracle 可从指定路径加载任何库并且不必提供库名称。如果将 ONLY 放在路径前面,Oracle 将仅使用路径中提供的特定库。
  18. KEY
  19. 为此条目设置的值将此侦听器链接到文件 tnsnames.ora 中的对应服务条目。该值将此侦听器与可能存在于同一数据库服务器的其他 IPC 侦听器区分开来。key 可为任何短名称,但在文件 listener.ora 和 tnsnames.ora 中必须相同。key 区分大小写。</span><span style="font-size:18px;">
  20. </span>

8:测试是否正常

  1. SQL> select sde.st_astext(shape) from  aa where objectid<3;
  2. SDE.ST_ASTEXT(SHAPE)
  3. ------------------------------------------------------------------
  4. POINT  ( -13625889.61620000 4541020.47880000)
  5. POINT  ( -13627070.41230000 4548787.04140000)

怎么配置 Oracle 侦听器来使用SQL操作ST_Geometry的更多相关文章

  1. 配置 Oracle 11g侦听器来使用SQL操作ST_Geometry(DLL路径问题)

    注:http://resources.arcgis.com/zh-cn/help/main/10.2/index.html#/na/00qn0000001p000000/ (ArcGIS 帮助库) 1 ...

  2. Vue.js 第2章 钩子函数&自定义指令&过滤器&计算属性&侦听器

    目标 钩子函数 自定义指令 自定义过滤器 计算属性 监听属性 局部自定义指令 为什么需要自定义指令 为了复用,为了代码的灵活 指令的分类:全局指令,局部指令 在vm外面创建的指令 通过Vue.dire ...

  3. 宣布正式发布 Windows Azure Notification Hub,新增 SQL Server AlwaysOn 可用性组侦听器支持

    今天,我们非常高兴地宣布,针对使用 Windows Azure 的移动和企业开发人员推出一些新功能.这些新功能可以减少构建移动应用程序的开发时间和成本,并能帮助企业开发人员实现高可用性和全球业务连续性 ...

  4. Vue.js之Vue计算属性、侦听器、样式绑定

    前言 上一篇介绍了Vue的基本概念,这一篇介绍一下Vue的基本使用. 一.搭建一个Vue程序 1.1 搭建Vue环境 搭建Vue的开发环境总共有三种方法: 引入CDN <script src=& ...

  5. 如何将数据库引擎配置为侦听多个 TCP 端口

    SQL Server 2005         为 SQL Server 启用 TCP/IP 后,数据库引擎将侦听连接点上是否有传入的连接(由 IP 地址和 TCP 端口号组成).下列步骤将创建一个表 ...

  6. 关于如何获取/清除 MAXScript 侦听器内的文本

    关于如何获取/清除 MAXScript 侦听器内的文本 用来保存记录?还没想到实际用处,先记上. macroRecorder as string listener as stringclearList ...

  7. JavaScript DOM高级程序设计 4.3控制事件流和注册事件侦听器--我要坚持到底!

    一.事件流 我们通过下面一个实例,进行说明. <body> <h1>Event Flow</h1> <ul id="nav"> &l ...

  8. js事件流、事件处理程序/事件侦听器

    1.事件流 事件冒泡 IE的事件流叫做事件冒泡(event bubbling),即事件开始时由最具体的元素(文档中嵌套层次最深的那个节点)接收,然后逐级向上传播到较为不具体的节点(文档). 事件捕获 ...

  9. Android事件侦听器回调方法浅谈

    http://developer.51cto.com/art/201001/180846.htm Android事件侦听器作为视图View类的接口,其中包含有不少回调方法,比如:onClick():o ...

随机推荐

  1. [Cerc2012]Non-boring sequences

    Description 定义一个序列是不无聊的,当且仅当它的所有子区间都存在一个独一无二的数字,即每个子区间里至少存在一个数字只出现过一次.给定一个长度为\(N(N\leq2\times 10^5)\ ...

  2. js jq输入框中按回车触发提交事件,用户在页面输入后按回车(Enter键)进行

    js jq输入框中按回车触发提交事件,用户在页面输入后按回车(Enter键)进行 代码如下: <!DOCTYPE html> <html lang="en" xm ...

  3. 大数据之 Spark

    1 渊源 于2009由Matei Zaharia创立了spark大数据处理和计算框架,基于内存,用scala编写. 2 部署 2.1 需要软件包 下载路径见已有博文 Jdk ——因为运行环境为jvm ...

  4. webpack4 系列教程(四): 单页面解决方案--代码分割和懒加载

    本节课讲解webpack4打包单页应用过程中的代码分割和代码懒加载.不同于多页面应用的提取公共代码,单页面的代码分割和懒加载不是通过webpack配置来实现的,而是通过webpack的写法和内置函数实 ...

  5. 网页布局设计css中单位px和em,rem的区别

    国内的设计师大都喜欢用px,而国外的网站大都喜欢用em和rem,那么三者有什么区别,又各自有什么优劣呢? PX特点 1. IE无法调整那些使用px作为单位的字体大小: 2. 国外的大部分网站能够调整的 ...

  6. js 绘制数学函数

    <!-- <!doctype html> --> <html lang="en"> <head> <meta charset= ...

  7. bootstrap网站后台从设计到开发之登录

    节后综合征缓了两天,今天把登录界面的主要后台代码分享给大家. protected void Page_Load(object sender, EventArgs e) { if (!Page.IsPo ...

  8. √n求单值欧拉函数

    基本定理: 首先看一下核心代码: 核心代码 原理解析: 当初我看不懂这段代码,主要有这么几个问题: 1.定理里面不是一开始写了一个n*xxx么?为什么代码里没有*n? 2.ans不是*(prime[i ...

  9. mysql之行(记录)的详细操作

    在Mysql管理软件中, 可以通过sql语句中的dml语言来实现数据的操作, 包括 使用INSERT实现数据的插入 UPDATE实现数据的更新 使用DELETE实现数据的删除 使用SELECT查询数据 ...

  10. 03--css形状--css揭秘

    形状 一 自适应的椭圆 1.难题 1> 圆 你可能注意到过, 给任何正方形元素设置一个足够大的border-radius, 就可以把它变成一个圆形.所用到的CSS 代码如下所示: #bd { w ...