tname | cname | datatype | cnumber | tabowner |
Salespeople | snum | integer | 1 | Diane |
Salespeople | sname | char | 2 | Diane |
Salespeople | city | char | 3 | Diane |
Salespeople | comm | decimal | 4 | Diane |
Customers | cnum | integer | 1 | Diane |
Customers | cname | char | 2 | Diane |
Customers | city | char | 3 | Diane |
Customers | rating | integer | 4 | Diane |
Customers | snum | integer | 5 | Diane |
Orders | onum | integer | 1 | Diane |
Orders | odate | date | 2 | Diane |
Orders | amt | decimal | 3 | Diane |
Orders | cnum | integer | 4 | Diane |
Orders | snum | integer | 5 | Diane |
Как вы можете видеть, каждая строка этой таблицы показывает столбец таблицы в базе данных. Все столбцы данной таблицы должны иметь разные имена, также как каждая таблица должна иметь данного пользователя, и наконец все комбинации пользователей, таблиц, и имен столбцов должны различаться между собой.
Следовательно табличные столбцы: tname (имя таблицы ), tabowner (владелец таблицы ), и cname (имя столбца ), вместе составляют первичный ключ этой таблицы. Столбец datatype( тип данных ) говорит сам за себя. Столбец cnumber (номер столбца ) указывает на местоположении этого столбца внутри таблицы. Для упрощения, мы опустили параметры длины столбца, точности, и масштаба.
Для справки, показана строка из SYSTFMCATALOG которая ссылается к этой таблице:
tname | owner | numcolumns | type | CO |
SYSTEMCOLUMNS | System | 8 | B |
Некоторые SQL реализации, будут обеспечивать вас большим количеством данных чем показано в этих столбцах, но показанное являются основой для любый реализаций.
Для иллюстрации процедуры предложенной в начале этого раздела, имеется способ, позволяющий каждому пользователю видеть информацию SYSTEMCOLUMNS только для принадлежащих ему таблиц:
CREATE VIEW Owncolumns
AS SELECT *
FROM SYSTEMCOLUMNS
WHERE tabowner=USER;
GRANT SELECT ON Owncolumns TO PUBLIC;
Большинство версий SQL, позволяют вам помещать комментарии(ремарки) в специальные столбцы пояснений таблиц каталогов SYSTEMCATALOG и SYSTEMCOLUMNS, что удобно, так как эти таблицы не всегда могут объяснить свое содержание. Для простоты, мы пока исключали этот столбец из наших иллюстраций.
Можно использовать команду 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 ";
и этот пустой комментарий затрет предыдущий.
SELECT tname, remarks FROM SYSTEMCATALOG
WHERE tname='Orders' AND owner='Chris'
tname | remarks |
Orders | Current Customers Orders |
Таблица 24.2: Коментарий в SYSTEMCATALOG
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 и их описания - следующие: