当前位置:Gxlcms > mysql > 怎么配置Oracle侦听器来使用SQL操作ST

怎么配置Oracle侦听器来使用SQL操作ST

时间:2021-07-01 10:21:17 帮助过:39人阅读

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

关于这个内容,其实从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关键字,所以我们需要修改为这个关键字即可。

人气教程排行