Dans Oracle, les fonctions SQL ST_Geometry utilisent une bibliothèque partagée accessible via l’agent de procédure externe Oracle, ou extproc. Oracle doit pouvoir accéder au fichier de bibliothèque physique pour que vous puissiez effectuer l’une des actions suivantes :
- Exécutez les fonctions SQL ST_Geometry à partir de clients SQL.
- Accédez aux colonnes XML dans les vues système des géodatabases GDB_ITEMS_VW et GDB_ITEMRELATIONSHIPS_VW.
- Définissez une couche de requête dans ArcMap ou ArcGIS Pro qui exécute les fonctions SQL sur les colonnes ST_Geometry.
- Publiez les données à partir de la base de données Oracle.
Configurez la structure de procédure externe Oracle pour appeler la bibliothèque ST_Geometry afin d’effectuer ces tâches.
Avant de configurer le fichier extproc Oracle, procédez de la manière suivante :
- Si votre instance d’Oracle n’a pas accès aux emplacements d’installation d’ArcGIS Server ou d’ArcMap notés ci-dessus, téléchargez la bibliothèque ST_Geometry à partir de My Esri ou copiez le fichier à partir de l’ordinateur client ArcGIS dans un répertoire de la machine Oracle. Veillez à copier la bibliothèque correspondant au système d'exploitation Oracle.
- Les outils de géotraitement Créer le type spatial, Créer la géodatabase d'entreprise et Activer une géodatabase d'entreprise définissent un chemin par défaut pour la bibliothèque ST_SHAPELIB. Connectez-vous à l'instance d'Oracle en tant qu'utilisateur SDE à partir d'un client SQL et exécutez la commande SQL suivante pour voir le chemin défini pour la bibliothèque ST_SHAPELIB :
SELECT file_spec FROM user_libraries WHERE library_name = 'ST_SHAPELIB';
Si le chemin retourné par la commande ne correspond pas à l’emplacement de la bibliothèque ST_Geometry, recréez la bibliothèque après avoir configuré le fichier extproc.
Configurez le fichier fichier Oracle extproc.ora de sorte qu’il pointe sur l’emplacement du fichier de bibliothèque ST_Geometry.
- Faites une copie de sauvegarde du fichier extproc.ora sur le serveur Oracle.
- Ouvrez le fichier extproc.ora et modifiez-le pour qu’il désigne l’emplacement de la bibliothèque st_shapelib.dll (Windows) ou libst_shapelib.so (Linux ou UNIX).
Dans cet exemple, aucun client ArcGIS n’est installé sur le serveur Windows Oracle. Par conséquent, la bibliothèque st_shapelib.dll a été copiée dans un répertoire nommé mylibraries sur la machine Oracle. La ligne suivante est ajoutée à extproc.ora pour désigner la bibliothèque ST_Geometry dans ce répertoire :
SET EXTPROC_DLLS=ONLY:C:\\mylibraries\\st_shapelib.dll
Dans cet exemple, sur un serveur Linux ou UNIX, la ligne suivante est ajoutée pour désigner la bibliothèque ST_Geometry dans le répertoire esrilibs de l’utilisateur, créé sur le serveur Oracle pour stocker la bibliothèque :
SET EXTPROC_DLLS=ONLY:/user/esrilibs/libst_shapelib.so
- Enregistrez et fermez le fichier extproc.ora.
Vous pouvez être amené à redémarrer l’instance Oracle pour qu’elle reconnaisse les modifications apportées au fichier extproc.ora.
- Si vous avez modifié l'emplacement du fichier de bibliothèque ST_Geometry par rapport à l'emplacement par défaut ou si aucun emplacement n'a été défini, créez ou recréez la bibliothèque ST_SHAPELIB dans la base de données Oracle.
Dans cet exemple, la bibliothèque ST_SHAPELIB est définie sur le répertoire mylibraries sur un serveur Oracle Windows, dans lequel le fichier st_shapelib.dll a été placé.
CREATE or REPLACE LIBRARY ST_SHAPELIB AS 'C:\mylibraries\st_shapelib.dll';
- Si vous avez recréé la bibliothèque, recompilez le paquetage sde.st_geometry_shapelib_pkg.
ALTER PACKAGE sde.st_geometry_shapelib_pkg COMPILE REUSE SETTINGS;
- Les clients qui doivent accéder à la bibliothèque (y compris les services Web) doivent se reconnecter à la base de données.