Récapitulatif
Cet outil est utilisé dans des bases de données et des géodatabases d'entreprise, de groupe de travail et de bureau pour recréer des index attributaires ou spatiaux existants. Dans les géodatabases d'entreprise, de groupe de travail et de bureau, 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 versionnés. 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, de groupe de travail ou de bureau, Cet outil ne fonctionne pas avec les géodatabases fichier ou personnelle.
- 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.
Syntaxe
RebuildIndexes_management (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.
| 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. | Dataset |
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 |
Exemple de code
Exemple 1 d'utilisation de l'outil Recréer les index (fenêtre Python)
L'exemple suivant montre comment recréer des index à l'aide d'une fenêtre Python dans ArcGIS.
# Import system modules
import arcpy
arcpy.RebuildIndexes_management("c:/Connections/GDB@DC@server.sde", "NO_SYSTEM","db1.GDB.Roads;db1.GDB.Parcels", "ALL")
Exemple 2 d'utilisation de l'outil Recréer les index (script autonome)
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
- ArcGIS for Desktop Basic: Annuler
- ArcGIS for Desktop Standard: Oui
- ArcGIS for Desktop Advanced: Oui