Las funciones SQL de ST_Geometry en Oracle usan una biblioteca compartida a la que Oracle accede a través del agente de procedimiento externo de Oracle, o extproc. Oracle necesita acceder al archivo de biblioteca físico para realizar cualquiera de las siguientes tareas:
- Ejecutar funciones ST_Geometry de SQL desde clientes SQL.
- Definir una capa de consulta que ejecute funciones SQL en columnas de ST_Geometry.
- Consultar capas de entidades en bins en ArcGIS Pro.
- Publicar una capa web que haga referencia a los datos de la base de datos de Oracle.
- Ejecute la herramienta de geoprocesamiento Seleccionar capa por ubicación con la opción Intersecar (DBMS).
Debe configurar el marco de procedimiento externo de Oracle para llamar a la biblioteca ST_Geometry (ST_SHAPELIB) para realizar las tareas enumeradas anteriormente.
Pasos preparatorios
La biblioteca ST_Geometry se crea para sistemas operativos específicos. Puede descargar el archivo de biblioteca específico para su sistema operativo y versión de cliente desde My Esri.
La instancia de Oracle debe tener acceso a la biblioteca ST_Geometry. Coloque la biblioteca en el equipo de Oracle en un directorio al que pueda acceder la instancia de Oracle.
Antes de configurar el archivo extproc de Oracle, siga estos pasos:
- Descargue la biblioteca ST_Geometry desde My Esri y colóquela en un directorio del equipo de Oracle.
Nota:
Asegúrese de descargar o copiar la biblioteca correcta para su sistema operativo Oracle.
La biblioteca ST_Geometry necesita el paquete redistribuible de Microsoft Visual C++ (x64) cuando se implementa en un servidor de Microsoft Windows. Consulte Requisitos de ArcGIS Oracle para conocer la versión del paquete que se requiere. Si este paquete no está presente en el servidor de Oracle, descárguelo desde el sitio web de Microsoft e instálelo.
- Conéctese a la instancia de Oracle como usuario sde desde un cliente SQL y ejecute el siguiente SQL para confirmar que la ruta establecida por la herramienta coincide con la ubicación de la biblioteca ST_Geometry:
SELECT file_spec FROM user_libraries WHERE library_name = 'ST_SHAPELIB';
Si la ruta obtenida no coincide con la ubicación del archivo de la biblioteca ST_Geometry, cree de nuevo la biblioteca después de configurar extproc.
Configurar extproc
Configure el archivo Oracle de extproc.ora para que apunte a la ubicación del archivo de la biblioteca ST_Geometry.
- Realice una copia de seguridad del archivo extproc.ora en el servidor de Oracle.
- Abra el archivo extproc.ora en un editor de texto y modifíquelo para que apunte a la ubicación de la biblioteca st_shapelib.dll (Windows) o libst_shapelib.so (Linux o UNIX).
En este ejemplo, el archivo st_shapelib.dll se ha copiado en un directorio llamado mylibraries en el equipo de Oracle. La línea siguiente se agrega a extproc.ora para que apunte a la biblioteca ST_Geometry en ese directorio:
SET EXTPROC_DLLS=ONLY:C:\\mylibraries\\st_shapelib.dll
En este ejemplo en un servidor Linux o UNIX, se agrega la siguiente línea para que señale la biblioteca ST_Geometry del directorio esrilibs del usuario, que se creó en el servidor de Oracle para almacenar la biblioteca:
SET EXTPROC_DLLS=ONLY:/user/esrilibs/libst_shapelib.so
- Guarde y cierre el archivo extproc.ora.
Puede que tenga que reiniciar la instancia de Oracle para que identifique los cambios en el archivo extproc.ora.
- Si cambió la ubicación predeterminada del archivo de la biblioteca ST_Geometry o si no se definió ninguna ubicación, cree o vuelva a crear la biblioteca ST_SHAPELIB en la base de datos de Oracle.
Debe conectarse a una base de datos como el usuario sde para crear o volver a crear la biblioteca ST_Geometry.
En este ejemplo, la biblioteca ST_SHAPELIB está definida en el directorio mylibraries de un servidor de Oracle Windows donde se ubicó el archivo st_shapelib.dll.
CREATE or REPLACE LIBRARY ST_SHAPELIB AS 'C:\mylibraries\st_shapelib.dll';
- Si ha creado la biblioteca de nuevo, vuelva a compilar el paquete sde.st_geometry_shapelib_pkg.
ALTER PACKAGE sde.st_geometry_shapelib_pkg COMPILE REUSE SETTINGS;
Cualquier cliente que necesite tener acceso a la biblioteca (servicios Web incluidos) debe volver a conectarse a la base de datos.
Validar la configuración de extproc
Puede consultar la biblioteca ST_Geometry para asegurarse de que extproc pueda acceder a ella.
- Inicie sesión en un cliente SQL Oracle.
- Ejecute la siguiente consulta:
SELECT sde.ST_AsText(SDE.ST_Geometry('POINT (10 10)', 0)) FROM dual;
Si extproc está configurado correctamente, la consulta devolverá lo siguiente:
SDE.ST_ASTEXT(SDE.ST_GEOMETRY('POINT(1010)',0)) -------------------------------------------------------------------------------- POINT ( 10.00000000 10.00000000)
Si extproc no está configurado correctamente, puede ver uno o varios de los siguientes mensajes de error:
ORA-06520: PL/SQL: Error al cargar la biblioteca externa
ORA-06522: No se puede cargar la DLL
ORA-06512: en "SDE.ST_GEOMETRY_SHAPELIB_PKG", línea 0
ORA-06512: en "SDE.ST_GEOMETRY_OPERATORS", line 68
Actualizaciones y la biblioteca ST_Geometry
Debe descargar o copiar nuevas versiones del archivo de biblioteca para obtener las correcciones y mejoras incluidas en las nuevas versiones de la biblioteca cada vez que actualice la geodatabase en Oracle o necesite actualizar el tipo ST_Geometry en una base de datos de Oracle.
Oracle puede marcar la biblioteca como no válida al reemplazarla o después de actualizar la instancia de Oracle. Oracle a veces vuelve a compilar automáticamente objetos de base de datos no válidos cuando un cliente hace referencia a dichos objetos, pero hay casos en los que no se compilan automáticamente.
La biblioteca ST_Geometry pertenece al usuario sde. Para verificar el estado de la biblioteca (y todos los archivos propiedad del usuario sde), inicie sesión en un cliente SQL como el usuario sde y ejecute la siguiente instrucción:
SELECT object_name, object_type
FROM USER_OBJECTS
WHERE STATUS = 'INVALID';
Si el cuerpo del paquete de sde.st_geometry_shapelib_pkg se devuelve en la lista de objetos no válidos, vuelva a compilarlo como se describe en el paso 5 de la sección Configurar extproc de más arriba.
Si más de un objeto no es válido, puede recompilar todos los objetos en el mismo esquema. Consulte la documentación de Oracle para conocer los privilegios requeridos e instrucciones para recompilar varios objetos a la vez.