WikiDer > Метаданные Oracle
Эта статья не цитировать любой источники. (Июль 2012 г.) (Узнайте, как и когда удалить этот шаблон сообщения) |
База данных Oracle предоставляет информацию обо всех столы, взгляды, столбцы, и процедуры в базе данных. Эта информация об информации известна как метаданные. Он хранится в двух местах: в таблицах словаря данных (доступ к которым осуществляется через встроенные представления) и в реестре метаданных.
Другой системы управления реляционными базами данных поддержать ANSI-стандартный эквивалент, называемый информационная схема.
Представления для метаданных
Общее количество этих представлений зависит от версии Oracle, но находится в диапазоне 1000.
Основные встроенные представления доступа к Oracle СУБД таблиц словаря данных немного, и они следующие:
- ALL_OBJECTS - список всех объектов в текущей базе данных, доступных текущему пользователю;
- ALL_TABLES - список всех таблиц в текущей базе данных, доступных текущему пользователю;
- ALL_VIEWS - список всех представлений в текущей базе данных, доступных текущему пользователю;
- ALL_TAB_COLUMNS - список всех столбцов в базе данных, доступных текущему пользователю;
- ALL_ARGUMENTS - перечисляет аргументы функций и процедур, которые доступны текущему пользователю;
- ALL_ERRORS - перечисляет описания ошибок для всех хранимых объектов (представлений, процедур, функций, пакетов и тел пакетов), доступных текущему пользователю;
- ALL_OBJECT_SIZE - включен для обратной совместимости с Oracle версии 5;
- ALL_PROCEDURES - (начиная с Oracle 9 и далее) перечисляет все функции и процедуры (вместе со связанными свойствами), которые доступны текущему пользователю;
- ALL_SOURCE - описывает текстовый (т.е. PL / SQL) источник хранимых объектов, доступный текущему пользователю;
- ALL_TRIGGERS - список всех триггеров, доступных текущему пользователю.
Кроме того, существуют эквивалентные представления с префиксом «USER_», которые показывают только объекты, принадлежащие текущему пользователю (т. Е. Более ограниченное представление метаданных), и с префиксом «DBA_», которые показывают все объекты в базе данных (т. Е. Неограниченное глобальное представление метаданных для экземпляр базы данных). Естественно, для доступа к представлениям метаданных "DBA_" требуются определенные привилегии.
Пример 1: поиск таблиц
Найдите все таблицы, в имени которых есть ШАБЛОН
ВЫБРАТЬ Владелец В КАЧЕСТВЕ Schema_Name, Table_Name ИЗ Все_таблицы КУДА Table_Name ПОДОБНО '%ШАБЛОН%' ПОРЯДОК К Владелец, Table_Name;
Пример 2: поиск столбцов
Найдите все таблицы, в которых есть хотя бы один столбец, который соответствует определенному ШАБЛОНУ в имени столбца
ВЫБРАТЬ Владелец В КАЧЕСТВЕ Schema_Name, Table_Name, Column_Name ИЗ All_Tab_Columns КУДА Column_Name ПОДОБНО '%ШАБЛОН%' ПОРЯДОК К 1,2,3;
Пример 3: подсчет строк столбцов
Оцените общее количество строк во всех таблицах, содержащих имя столбца, соответствующее ШАБЛОНУ (это SQL * Plus конкретный сценарий)
СТОЛБЕЦ ДУРАЧОК НОПРИНТ Вычислить СУММ ИЗ NUM_ROWS НА ДУРАЧОК ПЕРЕМЕНА НА ДУРАЧОК ВЫБРАТЬ НОЛЬ ДУРАЧОК, Т.ТАБЛИЦА ИМЯ, C.COLUMN_NAME, Т.NUM_ROWS ИЗ ALL_TABLES Т, ALL_TAB_COLUMNS C КУДА Т.ТАБЛИЦА ИМЯ = C.ТАБЛИЦА ИМЯ И C.COLUMN_NAME ПОДОБНО '%ШАБЛОН%' И Т.ВЛАДЕЛЕЦ = C.ВЛАДЕЛЕЦ ПОРЯДОК К Т.ТАБЛИЦА ИМЯ;
Обратите внимание, что NUM_ROWS записывает количество строк, которые были в таблице, когда (и если) она последний раз анализировалась. Это, скорее всего, будет отличаться от фактического количества строк в таблице в данный момент.
Пример 4: поиск столбцов представления
Найти столбцы просмотра
ВЫБРАТЬ ТАБЛИЦА ИМЯ, имя_столбца, расшифровать(c.ТИП ДАННЫХ, 'VARCHAR2', c.ТИП ДАННЫХ || '(' || c.DATA_LENGTH || ')', 'НОМЕР', ДЕКОДИРОВАТЬ(c.data_precision, НОЛЬ, c.ТИП ДАННЫХ, 0, c.ТИП ДАННЫХ, c.ТИП ДАННЫХ || '(' || c.data_precision || ДЕКОДИРОВАТЬ(c.data_scale, НОЛЬ, ')', 0, ')' , ', ' || c.data_scale || ')')), c.ТИП ДАННЫХ) тип данных ИЗ cols c, объект о КУДА c.ТАБЛИЦА ИМЯ = о.имя_объекта И о.object_type = 'ПОСМОТРЕТЬ' И c.table_name ПОДОБНО '%ШАБЛОН%' ПОРЯДОК К c.table_name, c.column_id;
Предупреждение: это неполно в отношении нескольких типов данных, включая char, varchar и timestamp, и использует очень старые, устаревшие представления словаря, вплоть до oracle 5.
Использование подчеркивания в именах таблиц и столбцов
Подчеркивание - это особый SQL шаблон соответствует одному символу и должен быть экранирован, если вы действительно ищете символ подчеркивания в предложении LIKE запроса.
Просто добавьте следующее после оператора LIKE:
ПОБЕГ '_'
И затем каждое буквальное подчеркивание должно быть двойным подчеркиванием: __
Пример
КАК '% __ G' ESCAPE '_'
Реестр метаданных Oracle
Продукт Oracle Oracle Enterprise Metadata Manager (EMM) - это ISO / IEC 11179 совместимый реестр метаданных. Он хранит администрируемые метаданные в согласованном формате, который можно использовать для публикация метаданных. В январе 2006 года EMM было доступно только через консалтинговые услуги Oracle.