Résumé
Recréer les index attributaires ou spatiaux existants dans les géodatabases d’entreprise. Les index peuvent également être recréés dans les tables système de géodatabase states et state_lineage et les tables de deltas des jeux de données qui sont inscrits pour participer au versionnement traditionnel. Les index obsolètes peuvent réduire les performances des requêtes.
Utilisation
- Les données doivent provenir d’une base de données ou d’une géodatabase d’entreprise. Cet outil ne fonctionne pas avec les géodatabases fichier.
- Après des opérations de chargement, suppression, mise à jour et compression des données, il est important de récréer les index.
- Cet outil récrée les index spatiaux et attributaires des tables de base, des tables de deltas et des tables d'archive dans les géodatabases d'archivage et versionnées.
- Le paramètre Inclure les tables système détermine si les index sont recréés dans les tables d'états et de généalogies des états de la géodatabase spécifiée. Lorsque l'option est désélectionnée, les index de ces tables ne sont pas recréés. Si le paramètre Inclure les tables système est désactivé, au moins un jeu de données doit être sélectionné dans le paramètre Jeux de données pour lesquels recréer les index pour exécuter l'outil.
- Le bouton Ajouter une valeur du paramètre Datasets to Rebuild Indexes For est utilisé uniquement dans ModelBuilder. Dans ModelBuilder, si l'outil précédent n'a pas été exécuté ou si ses données dérivées n'existent pas, il se peut qu'aucune valeur ne soit renseignée dans le paramètre Jeux de données pour lesquels recréer les index. Le bouton Ajouter une valeur vous permet d'ajouter des valeurs prévues pour terminer la boîte de dialogue et poursuivre la création du modèle.
- Cet outil n’est pas pris en charge avec SAP HANA.
Syntaxe
arcpy.management.RebuildIndexes(input_database, include_system, {in_datasets}, {delta_only})
Paramètre | Explication | Type de données |
input_database | Connexion (fichier .sde) à la base de données ou géodatabase qui contient les données pour lesquelles vous souhaitez recréer les index. | Workspace |
include_system | Indique si les index seront recréés sur les états et tables de généalogies des états. Remarque :Vous devez vous connecter en tant qu'administrateur de géodatabase dans le fichier de connexion spécifié pour la input_database pour que cette option s'exécute correctement. Cette option s'applique uniquement aux géodatabases. Cette option est ignorée si vous vous connectez à une base de données.
| Boolean |
in_datasets [in_datasets,...] (Facultatif) | Noms des jeux de données dont les index sont recréés. Les noms des jeux de données utilisent des chemins d'accès relatifs à la input_database ; les chemins complets ne sont pas acceptés en tant qu'entrée. | String |
delta_only (Facultatif) | Indique la façon dont les index sont recréés sur les jeux de données sélectionnés. Cette option est sans effet si le champ in_datasets est vide. Cette option s'applique uniquement aux géodatabases. Si l'espace de travail en entrée est une base de données, cette option est ignorée.
| Boolean |
Sortie dérivée
Nom | Explication | Type de données |
out_workspace | Espace de travail mis à jour. | Espace de travail |
Exemple de code
L'exemple suivant montre comment recréer des index à l'aide d'une fenêtre Python.
# Import system modules
import arcpy
arcpy.RebuildIndexes_management("c:/Connections/GDB@DC@server.sde", "NO_SYSTEM","db1.GDB.Roads;db1.GDB.Parcels", "ALL")
L'exemple suivant montre comment recréer des index dans un script autonome.
# Name: RebuildIndexes.py
# Description: rebuilds indexes on delta tables for all datasets in an
# enterprise geodatabase
# Import system modules
import arcpy, os
# set workspace
workspace = arcpy.GetParameterAsText(0)
# set the workspace environment
arcpy.env.workspace = workspace
# NOTE: Rebuild indexes can accept a Python list of datasets.
# Get a list of all the datasets the user has access to.
# First, get all the stand alone tables, feature classes and rasters.
dataList = arcpy.ListTables() + arcpy.ListFeatureClasses() + arcpy.ListRasters()
# Next, for feature datasets get all of the datasets and featureclasses
# from the list and add them to the master list.
for dataset in arcpy.ListDatasets("", "Feature"):
arcpy.env.workspace = os.path.join(workspace,dataset)
dataList += arcpy.ListFeatureClasses() + arcpy.ListDatasets()
# reset the workspace
arcpy.env.workspace = workspace
# Get the user name for the workspace
userName = arcpy.Describe(workspace).connectionProperties.user.lower()
# remove any datasets that are not owned by the connected user.
userDataList = [ds for ds in dataList if ds.lower().find(".%s." % userName) > -1]
# Execute rebuild indexes
# Note: to use the "SYSTEM" option the workspace user must be an administrator.
arcpy.RebuildIndexes_management(workspace, "NO_SYSTEM", userDataList, "ALL")
print('Rebuild Complete')
Environnements
Informations de licence
- Basic: Non
- Standard: Oui
- Advanced: Oui
Rubriques connexes
Vous avez un commentaire à formuler concernant cette rubrique ?