Можно использовать команду COMMENT ON со строкой текста, чтобы пояснить любую строку в одной из этих таблиц. Состояние - TABLE, для комментирования в SYSTEMCATALOG, и текст - COLUMN, для SYSTEMCOLUMNS.
Например:
COMMENT ON TABLE Chris.Orders
IS 'Current Customer Orders';
Текст будет помещен в столбец пояснений SYSTEMCATALOG. Обычно, максимальная длина таких пояснений - 254 символов.
Сам комментарий, указывается для конкретной строки, одна с tname=Orders, а другая owner=Chris. Мы увидим этот комментарий в строке для таблицы Порядков в SYSTEMCATALOG:
SELECT tname, remarks
FROM SYSTEMCATALOG
WHERE tname='Orders'
AND owner='Chris';
Вывод для этого запроса показывается в Таблица 24.2.
SYSTEMCOLUMNS работает точно так же. Сначала, мы создаем комментарий
COMMENT ON COLUMN Orders.onum
IS 'Order #';
затем выбираем эту строку из SYSTEMCOLUMNS:
SELECT cnumber, datatype, cname, remarks
FROM SYSTEMCOLUMNS
WHERE tname='Orders'
AND tabowner='Chris'
AND cname=onum;
Вывод для этого запроса показывается в Таблице 24.3.
Чтобы изменить комментарий, вы можете просто ввести новую команду COMMENT ON для той же строки. Новый комментарий будет записан поверх старого. Если вы хотите удалить комментарий, напишите поверх него пустой комментарий, подобно следующему:
COMMENT ON COLUMN Orders.onum
IS ";
и этот пустой комментарий затрет предыдущий.
SQL Execution Log
SELECT tname, remarks FROM SYSTEMCATALOG
WHERE tname='Orders' AND owner='Chris'
tname
|
remarks
|
Orders
|
Current Customers Orders
|
Таблица 24.2: Коментарий в SYSTEMCATALOG
SQL Execution Log
SELECT cnumber, datatype, cname, remarks
FROM SYSTEMCOLUMNS WHERE tname='Orders' AND tabowner='Chris'
AND cname='onum'
cnumber
|
datatype
|
cname
|
remarks
|
1
|
integer
|
onum
|
Orders #
|
Таблица 24.3: Коментарий в SYSTEMCOLUMNS
ОСТАЛЬНОЕ ИЗ КАТАЛОГА
Здесь показаны оставшиеся из ващих системных таблиц определения, с типовым запросом для каждого:
SYSTEMINDEXES - ИНДЕКСАЦИЯ В БАЗЕ ДАННЫХ
Имена столбцов в таблице SYSTEMINDEXES и их описания - следующие:
СТОЛБЦЫ
|
ОПИСАНИЕ
|
iname
|
Имя индекса (используемого для его исключения )
|
iowner
|
Имя пользователя который создал индекс
|
tname
|
Имя таблицы которая содержит индекс
|
cnumber
|
Номер столбца в таблице
|
tabowner
|
Пользователь который владеет таблицей содержащей индекс
|
numcolumns
|
Число столбцов в индексе
|
cposition
|
Позиция текущего столбца среди набора индексов
|
isunique
|
Уникален ли индекс (Y или N )
|
ТИПОВОЙ ЗАПРОС
Индекс считается неуникальным, если он вызывает продавца, в snum столбце таблицы Заказчиков:
SELECT iname, iowner, tname, cnumber, isunique
FROM SYSTEMINDEXES
WHERE iname='salesperson';
Вывод для этого запроса показывается в Таблице 24.4.
SQL Execution Log
SELECT iname, iowner, tname, cnumber, isunique
FROM SYSTEMINDEXES WHERE iname='salespeople';
iname
|
iowner
|
tname
|
cnumber
|
isunique
|
salesperson
|
Stephan
|
Customers
|
5
|
N
|
Таблица 24.4: Строка из таблицы SYSTEMINDEXES
SYSTEMUSERAUTH - ПОЛЬЗОВАТЕЛЬСКИЕ И СИСТЕМНЫЕ ПРИВИЛЕГИИ В БАЗЕ ДАННЫХ
Имена столбцов для SYSTEMUSERAUTH и их описание, следующее:
Столбцы
|
Описание
|
username
|
Идентификатор (ID ) доступа пользователя
|
password
|
Пароль пользователя вводимый при регистрации
|
resource
|
Где пользователь имеет права RESOURCE
|
dba
|
Где пользователь имеет права DBA
|
Мы будем использовать простую схему системных привилегий, которая представлена в Главе 22, где были представлены три системных привилегии - CONNECT( ПОДКЛЮЧИТЬ ), RESOURCE( РЕСУРСЫ ) и DBA. Все пользователи получают CONNECT по умолчанию при регистрации, поэтому он не описан в таблице выше. Возможные состояния столбцов resource и dba могут быть - Y (Да, пользователь имеет привилегии) или - No (Нет, пользователь не имеет привилегий).
Пароли (password) доступны только высоко привилегированным пользователям, если они существуют. Следовательно запрос этой таблицы можно вообще делать только для информации относительно привилегий системы и пользователей.
ТИПОВОЙ ЗАПРОС Чтобы найти всех пользователей которые имеют привилегию RESOURCE, и увидеть какие из них - DBA, вы можете ввести следующее условие:
SELECT username, dba
FROM SYSTEMUSERAUTH
WHERE resource='Y';
Вывод для этого запроса показывается в Таблице 24.5.
SYSTEMTABAUTH - ПРИВИЛЕГИИ ОБЪЕКТА ОТОРЫЕ НЕ ОПРЕДЕЛЯЮТ СТОЛБЦЫ
Читать дальше