Available with Standard or Advanced license.
The database uses indexes to quickly identify rows when a client queries the database. Most of the geodatabase system tables have indexes, but the tables that tend to have the greatest amount of change in an enterprise geodatabase that uses traditional versioning and, therefore, require the indexes to be rebuilt most often are the sde_states, sde_state_lineages, and sde_mvtables_modified system tables. As the geodatabase administrator, you can rebuild the indexes on these tables in enterprise geodatabases using the Rebuild Indexes geoprocessing tool.
In a heavily edited geodatabase that uses traditional versioning, you might update indexes on the sde_states, sde_state_lineages, and sde_mvtables_modified tables nightly. To do that, create a stand-alone Python script that calls the Rebuild Indexes tool and schedule it to run using Windows Scheduled Tasks or a cron job.
Use the Rebuild Indexes tool
To rebuild indexes on the sde_states, sde_state_lineages, and sde_mvtables_modified geodatabase system tables using the Rebuild Indexes tool, do the following:
- Start ArcGIS Pro and connect to the geodatabase as the geodatabase administrator.
- Open the Rebuild Indexes geoprocessing tool.
This tool can be found in the Geodatabase Administration toolset of the Data Management toolbox.
- Use the connection you created in step 1 as the Input Database Connection.
- Check the Include System Tables check box.
- Uncheck Rebuild Delta Tables Only.
- Click Run.
Schedule a Python script
To run the script, you must be able to connect to the geodatabase as the geodatabase administrator. You can either create a connection file (.sde) and point to that from the script or type the connection information directly in the script. Next, schedule the script to run using Microsoft Windows Scheduled Tasks or the Linux cron daemon.
- Copy one of the following scripts to a computer where Python and one of the following ArcGIS products are installed:
- ArcGIS Pro (Desktop Standard or Desktop Advanced)
- ArcGIS Server
Alter the scripts with information specific to your site.
In this example, the sde user connects to a PostgreSQL database:
# Name: RSysIdxpg.py # Description: Rebuilds indexes on the sde_states, sde_state_lineages, # and sde_mv_tables_modified tables in an enterprise geodatabase # in PostgreSQL. # Import system modules import sys import arcpy import os # Provide connection information platform = POSTGRESQL instance = pg_cluster account_authentication = DATABASE_AUTH username = gdb_admin password = gdb_admin_password database = database_name # Set local variables if os.name.lower() == "nt": slashsyntax = "\\" if os.environ.get("TEMP") == None: temp = "c:\\temp" else: temp = os.environ.get("TEMP") else: slashsyntax = "/" if os.environ.get("TMP") == None: temp = "/usr/tmp" else: temp = os.environ.get("TMP") Connection_File_Name = temp + slashsyntax + "connection.sde" # Check for the .sde file and delete it if present if os.path.exists(Connection_File_Name): os.remove(Connection_File_Name) #Variable defined within the script; other variable options commented out at the end of the line saveUserInfo = "SAVE_USERNAME" #DO_NOT_SAVE_USERNAME print ("Creating Database Connection File...") # Create Database Connection File # Usage: out_folder_path, out_name, database_platform, instance, account_authentication, username, password, save_user_pass, database arcpy.CreateDatabaseConnectionFile_management(temp, "connection.sde", platform, instance, account_authentication, username, password, saveUserInfo, database) # Rebuild indexes on system tables arcpy.RebuildIndexes_management(Connection_File_Name, "SYSTEM", "", "ALL") print ("Rebuild Complete")
- After you alter the script to contain your connection information, schedule the script to run at a specific time each night.
- On Windows, open Scheduled Tasks from the Control Panel and use the wizard to add a scheduled task. When asked what program to run, browse to your Python script.
- For an ArcGIS Server installation on Linux, create a cron text file that contains information on the day and time you want the script to run, and load the file into cron using the crontab program.
For example, the following information sets the Python script (named rsysidxdb2.py) to run every Wednesday at 10:00 p.m.:
0 22 * * 3 /usr/bin/rsysidxdb2.py
See the Linux man pages provided with your Linux installation for information on using cron.