Recréer les index (Gestion des données)

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 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. 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.
  • Cet outil n’est pas pris en charge avec SAP HANA.

Syntaxe

RebuildIndexes(input_database, include_system, {in_datasets}, {delta_only})
ParamètreExplicationType de données
input_database

Connexion (fichier .sde) à la géodatabase d'entreprise 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.

  • NO_SYSTEM Les index ne sont pas recréé sur les états et table de généalogies des états. Il s’agit de l’option par défaut.
  • SYSTEM Les index sont recréé 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.

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.

  • ALLLes index sont recréés sur tous les index des jeux de données sélectionnés. Cela inclut les index spatiaux ainsi que les index attributaires créés par l'utilisateur et tous les index gérés par géodatabase du jeu de données.
  • ONLY_DELTASLes index sont recréés uniquement pour les tables delta des jeux de données sélectionnés. Cette option peut être utilisée dans les cas où les tables métier des jeux de données sélectionnés ne sont pas souvent mises à jour est qu'un grand volume de modifications est apporté aux tables de deltas. Il s’agit de l’option par défaut.
Boolean

Sortie dérivée

NomExplicationType de données
out_workspace

Espace de travail mis à jour.

Espace de travail

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.

# 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')

Informations de licence

  • Basic: Non
  • Standard: Oui
  • Advanced: Oui

Rubriques connexes