INFORMATION_SCHEMA и Oracle |
||
Информационная схема (INFORMATION_SCHEMA) является стандартным представлением метаданных в языке SQL. Исторически каждый производитель реляционных СУБД предоставлял системные таблицы, которые содержали мета-информацию - имена таблиц, столбцов, ограничений, типы данных столбцов и т.д. Структура и состав системных таблиц могут меняться в разных версиях продукта, однако поддержка информационной схемы дает возможность менять структуру системных таблиц без изменения способа доступа к метаданным. Другим преимуществом применения INFORMATION_SCHEMA является то, что запросы к метаданным не зависят от используемой СУБД. Из ведущих производителей, пожалуй, только Oracle не поддерживает INFORMATION_SCHEMA. Справедливости ради следует сказать, что Oracle предоставляет возможность использовать системные представления вместо непосредственного обращения к системным таблицам, что также позволяет безопасно изменять структуру системных таблиц. Приведем ряд типичных запросов в стандартном варианте и для Oracle. 1. Список таблиц базы данных (текущей)Стандартное Oracle
2. Список столбцов заданной таблицы (например, PC)Стандартное
Oracle
3. Тип данных и размер заданного символьного столбца таблицы (столбец model таблицы PC)Стандартное
Oracle
4. Имя ограничения первичного ключа таблицы PCСтандартное
Oracle
5. Список столбцов, составляющих первичный ключ таблицы UtbСтандартное
Здесь мы в основном запросе получаем столбцы, участвующие в ограничениях, и выбираем те из них, у которых имя ограничения совпадает с именем ограничения первичного ключа для той же таблицы. В принципе, условие table_name='utb' основного запроса является избыточным с точки зрения получения правильного ответа, поскольку имя ограничения является уникальным для всей базы. Однако ранняя фильтрация существенно ускоряет выполнение запроса. Оракл
|