Определение
Используйте функцию Is_Archive_Enabled, чтобы определить, включена ли указанная таблица для архивирования. Если да, Is_Archive_Enabled возвращает TRUE; если нет, возвращается FALSE. Если таблица не зарегистрирована в базе геоданных, Is_Archive_Enabled возвращает NOT REGISTERED. В том случае, если таблица не существует в базе данных (например, если вы неправильно ввели ее название), будет возвращено сообщение, что таблица не зарегистрирована, поскольку Is_Archive_Enabled проверяет только наличие или отсутствие таблицы в системных таблицах базы геоданных.
Синтаксис
<geodatabase administrator schema>.is_archive_enabled(<table owner>, <table name>)
Тип возвращаемого значения
String
TRUE возвращается в случае, если указанная таблица зарегистрирована в базе геоданных и включена для архивирования.
FALSE возвращается в случае, если указанная таблица зарегистрирована в базе геоданных, но не включена для архивирования.
NOT REGISTERED возвращается в случае, если указанная таблица не зарегистрирована в базе геоданных, не существует в базе геоданных, или у вас нет доступа к таблице.
Примеры
Следующие примеры демонстрируют использование функции Is_Archive_Enabled для каждой поддерживаемой системы управления базами данных.
В первом примере, функция применяется для таблицы (деревья), которая не включена для архивирования.
Во втором примере, функция применяется для таблицы (птицы), которая включена для архивирования.
В третьем примере, функция применяется для таблицы (продажи), которая не зарегистрирована в базе геоданных.
IBM Db2
Пример 1
VALUES sde.IS_ARCHIVE_ENABLED('LOGIN1', 'TREES')
FALSE
Пример 2
VALUES sde.is_archive_enabled('LOGIN1', 'BIRDS')
TRUE
Пример 3
VALUES sde.is_archive_enabled('LOGIN5', 'SALES')
NOT REGISTERED
IBM Informix
Пример 1
EXECUTE FUNCTION sde.is_archive_enabled('login1', 'trees');
FALSE
Пример 2
EXECUTE FUNCTION sde.is_archive_enabled('login1', 'birds');
TRUE
Пример 3
EXECUTE FUNCTION sde.is_archive_enabled('login5', 'sales');
NOT REGISTERED
Microsoft SQL Server
Пример 1
DECLARE @owner varchar(128) = 'login1';
DECLARE @table varchar(128) = 'trees';
SELECT dbo.is_archive_enabled(@owner, @table) "Enabled for archiving?"
Enabled for archiving?
FALSE
Пример 2
DECLARE @owner varchar(128) = 'login1';
DECLARE @table varchar(128) = 'birds';
SELECT dbo.is_archive_enabled(@owner, @table) "Enabled for archiving?"
Enabled for archiving?
TRUE
Пример 3
DECLARE @owner varchar(128) = 'login5';
DECLARE @table varchar(128) = 'sales';
SELECT dbo.is_archive_enabled(@owner, @table) "Enabled for archiving?"
Enabled for archiving?
NOT REGISTERED
Oracle
Пример 1
SELECT sde.gdb_util.IS_ARCHIVE_ENABLED('LOGIN1', 'TREES') FROM DUAL;
SDE.GDB_UTIL.IS_ARCHIVE_ENABLED('LOGIN1', 'TREES') ---------------------------------------------------------
FALSE
Пример 2
SELECT sde.gdb_util.IS_ARCHIVE_ENABLED('LOGIN1', 'BIRDS') FROM DUAL;
SDE.GDB_UTIL.IS_ARCHIVE_ENABLED('LOGIN1', 'BIRDS') ---------------------------------------------------------
TRUE
Пример 3
SELECT sde.gdb_util.IS_ARCHIVE_ENABLED('LOGIN5', 'SALES') FROM DUAL;
SDE.GDB_UTIL.IS_ARCHIVE_ENABLED('LOGIN5', 'SALES') ---------------------------------------------------------
NOT REGISTERED
PostgreSQL
Пример 1
SELECT sde.is_archive_enabled('login1', 'trees');
FALSE
Пример 2
SELECT sde.is_archive_enabled('login1', 'birds');
TRUE
Пример 3
SELECT sde.is_archive_enabled('login5', 'sales');
NOT REGISTERED