Доступно с лицензией Standard или Advanced.
База данных использует индексы для быстрого нахождения строк, когда фильтр выполняет запрос к базе данных. У большинства системных таблиц базы геоданных есть индексы. Но в версионной многопользовательской базе геоданных с традиционными версиями есть таблицы, которые изменяются с наибольшей частотой. Для таких таблиц требуется наиболее частая перестройка индекса. Это следующие системные таблицы: sde_states, sde_state_lineages и sde_mvtables_modified. Как администратор базы геоданных, вы можете перестроить индексы в этих таблицах баз геоданных, используя инструмент геообработки Перестроить индексы.
В активно редактируемой версионной базе геоданных вы можете обновлять индексы в таблицах sde_states, sde_state_lineages и sde_mvtables_modified в ночное время. Для этого создайте автономный скрипт Python, вызывающий инструмент Перестроить индексы и планирующий его запуск с использованием Планировщика задач Microsoft Windows или задания cron.
Использование инструмента Перестроить индексы
Чтобы перестроить индексы в системных таблицах базы геоданных sde_states, sde_state_lineages и sde_mvtables_modified с помощью инструмента Перестроить индексы, необходимо сделать следующее:
- Запустите ArcGIS Pro и подключитесь к базе геоданных в качестве администратора базы геоданных.
- Откройте инструмент геообработки Перестроить индексы.
Он находится в группе инструментов Администрирование базы геоданных набора инструментов Управление данными.
- Используйте подключение, созданное на шаге 1, в качестве значения параметра Входное подключение к базе данных.
- Отметьте параметр Включить системные таблицы.
- Снимите отметку с параметра Перестроить только дельта-таблицы.
- Щелкните Запустить.
Планировка запуска скрипта Python
Для запуска скрипта необходимо подключиться к базе геоданных с правами доступа администратора базы геоданных. Вы можете либо создать файл подключения (.sde) и указать его в скрипте, либо ввести сведения о подключении непосредственно в скрипте. Далее установите расписание для запуска скрипта с помощью компонента Microsoft Windows Назначенные задания или с помощью демон-планировщика задач Linux cron системы Linux.
- Скопируйте один из следующих скриптов на компьютер, где установлены Python и один из следующих продуктов ArcGIS:
- ArcGIS Pro (Standard или Advanced)
- ArcGIS Server
Измените скрипты, внеся в них информацию о вашем сайте.
В следующем примере sde-пользователь подключается к базе PostgreSQL:
# 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") - После изменения скрипта, добавив в него сведения о подключении, запланируйте его выполнение в определённое время каждую ночь одним из следующих способов:
- В Windows, откройте Запланированные задачи через Панель управления и с помощью мастера добавьте новую задачу. Когда появится запрос на указание программы для запуска, укажите созданный вами скрипт Python.
- Для установки ArcGIS Server в Linux создайте текстовый файл cron, содержащий сведения о дне и времени запуска скрипта, и загрузите этот файл в cron с помощью программы crontab.
Например, для запуска скрипта Python (с именем rsysidxdb2.py) каждую среду в 22:00 необходимо ввести следующую информацию.
0 22 * * 3 /usr/bin/rsysidxdb2.py
Для получения сведений по использованию cron см. справочные страницы Linux, поставляемые вместе с операционной системой Linux.