Научная статья на тему 'Квазипроизвольные запросы к базам данных и информационная модель их реализации'

Квазипроизвольные запросы к базам данных и информационная модель их реализации Текст научной статьи по специальности «Компьютерные и информационные науки»

CC BY
192
37
i Надоели баннеры? Вы всегда можете отключить рекламу.
Ключевые слова
ПРОИЗВОЛЬНЫЕ ЗАПРОСЫ ПОЛЬЗОВАТЕЛЯ / ИНФОРМАЦИОННАЯ МОДЕЛЬ ПРЕДМЕТНОЙ ОБЛАСТИ / ФРЕЙМОВАЯ МОДЕЛЬ ПРЕДМЕТНОЙ ОБЛАСТИ / МОДЕЛЬ БИЗНЕС-ПРАВИЛ

Аннотация научной статьи по компьютерным и информационным наукам, автор научной работы — Оксанич И. Н.

Рассматриваются различные типы запросов пользователя-аналитика к тематической базе данных. Предлагается технология создания системы построения квазипроизвольных запросов пользователя. Построена информационная модель предметной области в виде совокупности трех составляющих: реляционной модели, фреймовой модели и модели бизнес-правил, обеспечивающая возможность создания системы построения квазипроизвольных запросов

i Надоели баннеры? Вы всегда можете отключить рекламу.

Похожие темы научных работ по компьютерным и информационным наукам , автор научной работы — Оксанич И. Н.

iНе можете найти то, что вам нужно? Попробуйте сервис подбора литературы.
i Надоели баннеры? Вы всегда можете отключить рекламу.

The different types of queries by user-analyst to the thematic database are discussed. A technology of creation system for constructing of quasi-arbitrary user queries is proposed. It is constructed the information model of domain as a set of three components: relational model, frame-based model and business rules model that provides the possibility of establishing a system for constructing of quasi-arbitrary queries

Текст научной работы на тему «Квазипроизвольные запросы к базам данных и информационная модель их реализации»

УДК 681.3

И.Н. ОКСАНИЧ

КВАЗИПРОИЗВОЛЬНЫЕ ЗАПРОСЫ К БАЗАМ ДАННЫХ И ИНФОРМАЦИОННАЯ МОДЕЛЬ ИХ РЕАЛИЗАЦИИ

Abstract. The different types of queries by user-analyst to the thematic database are discussed. A technology of creation system for constructing of quasi-arbitrary user queries is proposed. It is constructed the information model of domain as a set of three components: relational model, frame-based model and business rules model that provides the possibility of establishing a system for constructing of quasi-arbitrary queries.

Key words: arbitrary user requests, information domain model, frame-based domain model, business rules model.

Анотація. Розглядаються різні типи запитів користувача-аналітика до тематичної бази даних. Пропонується технологія створення системи побудови квазідовільних запитів користувача. Побудована інформаційна модель предметної області у вигляді сукупності трьох складових: реляційної моделі, фреймової моделі та моделі бізнес-правил, що забезпечує можливість створення системи побудови квазідовільних запитів. Ключові слова: довільні запити користувача, інформаційна модель предметної області, фреймова модель предметної області, модель бізнес-правил.

Аннотация. Рассматриваются различные типы запросов пользователя-аналитика к тематической базе данных. Предлагается технология создания системы построения квазипроизвольных запросов пользователя. Построена информационная модель предметной области в виде совокупности трех составляющих: реляционной модели, фреймовой модели и модели бизнес-правил, обеспечивающая возможность создания системы построения квазипроизвольных запросов.

Ключевые слова: произвольные запросы пользователя, информационная модель предметной области, фреймовая модель предметной области, модель бизнес-правил.

1. Введение

Одно из направлений повышения технологической эффективности процесса подготовки и принятия решений в СППР заключается в повышении оперативности доступа к информационным ресурсам со стороны пользователя-аналитика (ПА). В частности, типовыми ресурсами являются тематические базы данных (ТБД), содержащие информацию по определенной предметной области.

В зависимости от ожидаемой частоты обращений к тем или иным наборам данных базы данных (БД) выделяют следующие общие типы запросов [1]:

1. «Кнопочные» регламентированные запросы (КЗ), созданные заранее. Их описание и SQL-код сохранены в системе реализации запросов. Функциональность (разнообразие возможных вариантов искомых наборов данных) этих запросов минимальна, а оперативность доступа - максимальна. От ПА требуется только найти нужный запрос в предложенном перечне и дать команду на выполнение.

2. Параметрические регламентированные запросы (ПМЗ) тоже создаются заранее, но дают возможность пользователю специфицировать значения отдельных параметров, что расширяет функциональность при незначительном ухудшении оперативности доступа.

3. Произвольные нерегламентированные запросы (ПЗ). Эти запросы характеризуются максимальной функциональностью, поскольку открывают доступ ПА к любым наборам данных, но минимальной оперативностью, так как требуют применения специальных программных средств, а, зачастую, также и участия программистов.

Существует ряд стандартных программ различных фирм для построения произвольных запросов к базам данных (Query Builder фирмы Borland, Microsoft Query фирмы Microsoft и другие). Эти программы предоставляют графический интерфейс для создания произвольных запросов на

© Оксанич И.Н., 2010

ISSN 1028-9763. Математичні машини і системи, 2010, № 3

языке SQL и предназначены для работы программистов, хорошо разбирающихся в реляционных базах данных.

Средства создания нерегламентированных запросов, предоставляемые готовыми информационно-аналитическими системами (например, Oracle Discoverer) [2], сложны, нуждаются в дополнительном администрировании и специальной подготовке ПА.

В этой связи представляет практический интерес технология реализации запросов, занимающих промежуточное положение между ПМЗ и ПЗ в смысле функциональности, с одной стороны, и оперативности доступа к данным, с другой. Такая технология должна позволять формулировать и реализовывать on-line-запросы ПА, знакомого с предметной областью, без привлечения специально подготовленных лиц. Назовем такие запросы квазипроизвольными.

2. Технология создания КПЗ

Предлагаемое технологическое решение направлено на реализацию значительной части произвольных запросов, которые могут быть сформулированы ПА в терминах предметной области. Фактически речь идет о расширенном типе параметрических запросов, в которых пользователь специфицирует не только значение заданных параметров и условий, но и сами параметры.

Основой такой технологии является описание семантики ТБД на естественном языке (ЕЯ) пользователя, т.е. представление сущностей и атрибутов ТБД в терминах области ее применения, где сущность описывает семантический смысл таблицы ТБД, а атрибуты - это составляющие сущности, ее параметры (такое описание может быть сделано, например, с помощью case-средства PowerDesigner 9 фирмы Sybase). Для каждого атрибута существует его характеристика (текст, число, дата). Характеристика определяет метод получения данных по каждому атрибуту БД (правило).

Проанализировав любой пользовательский запрос, можно сделать вывод, что пользователь выбирает из базы данных одну или несколько сущностей с их атрибутами и накладывает определенные правила их нахождения, например, задавая диапазоны значений, временные характеристики и т.д.

Имея описание семантики сущностей и атрибутов всей базы данных, а также правил их нахождения, можно построить систему создания запросов, с помощью которой пользователь мог бы самостоятельно создавать и отрабатывать нужные ему запросы.

Предположим, что Si - сущность, Si.Aij - атрибуты сущности Si, R(Aij) - правило нахождения атрибута Aij.

Тогда пример БД может быть представлен следующим образом:

Si.Aij,R(Aij)^-— So.Aoi,R(Aoi) -—^ Si.Aij,R(Aij)---^ Sik.Aijk,R(Aijk)

I .

Si.Aij,R(Aij)

Правило нахождения R для атрибута Aij типа «число» может состоять из набора выражений

R(Aij) = {>, <, =, <>, <=, >=, содержит, не содержит, %, f(Aij)}.

Для атрибута Ai типа «Дата» получаем

R(Aij)={>, <, =, <>, <=, >=, диапазон, f(Aij)}.

Для атрибута Aij типа «Текст»

R(Aij) = {=, <>, усечение слева, усечение справа, усечение слева и справа, f(Aij)}, где f(Aij) - функция, которую можно применить к определенному атрибуту, например, sum, max, min, avg и т.д.

Исходя из вышеизложенного, можно привести следующий пример SQL-запроса:

Select So.Aoi, Si.Aij, Sum(Si.Aik) from So, Si where So.Aoi = K and Si.Aij=T and (So.Aoj Between T1 and T2) group by So.Aoi, Si.Aij,

где K, T, T1, T2 - константы, удовлетворяющие правилам R .

Таким образом, предлагаемая технология создания КПЗ на ЕЯ заключается в:

1) представлении сущностей и их атрибутов ТБД на ЕЯ в терминах предметной области с помощью case-средства (например, PowerDesigner 9);

2) определении правил нахождения различных атрибутов и функций, которые можно применить к ним, и в описании их на ЕЯ с помощью case-средства;

3) разработке интерфейса, в котором ПА предлагаются на выбор знакомые ему термины предметной области и правила их нахождения.

Основываясь на описанной технологии и разработав соответствующий интерфейс, можно

создать систему построения квазипроизвольных запросов (СПКПЗ) ПА к ТБД. Общий алгоритм функционирования СПКПЗ приведен на рис. 1.

3. Построение информационной модели КПЗ

В основе информационной модели СПКПЗ лежит информационная модель предметной области (ПрО).

Под ПрО будем понимать совокупность объектов некоторой ограниченной части внешнего мира, о которых ПА может задавать вопросы. ПА не может получить в ИС ответ на вопрос о том, что ей неизвестно.

Информационную модель ИнфМод ПрО, описывающую семантику предметной области, представим в виде совокупности 3-х составляющих (рис. 2):

• реляционной модели РелМод данных ПрО;

• фреймовой модели ФрМод ПрО;

• модели бизнес-правил БПрМод ПрО.

ИнфМод={РелМод, ФрМод, БпрМод}.

Рис. 2. Декомпозиционная схема информационной модели

РелМод данных ПрО включает в себя сущности РелСущ, их атрибуты РелАтр и отношения между сущностями Отн(сущн-сущн).

РелМод={РелСущ, РелАтр, Отн(сущн-сущн)}.

РелМод отражает структуру хранения данных в БД. Она, как правило, состоит из множества таблиц и отношений между ними. Эта модель сложна и не предназначена для работы ПА. Для того, чтобы ПА мог самостоятельно формировать запросы, нужна более простая и знакомая ПА структура понятий ПрО, в качестве которой может быть предложена фреймовая модель ПрО.

4. Фреймовая модель предметной области

Фреймовая модель представляет ПрО в виде жесткой иерархической структуры фреймов, в качестве которых выступают тематические разделы ПрО:

ФрМод={ФР, СЛ, ОТН(фр-фр)}, где ФР - фреймы (разделы ПрО, состоящие из одного или нескольких понятий ПрО);

СЛ - слоты (термины разделов ПрО, которые могут принимать определенные значения); ОТН(фр-фр) - связь между фреймами.

Фреймы и слоты в данной модели располагаются в строгом порядке в соответствии с их показателями важности (приоритета) wi, определенными по шкале 1,2,3,...п. В начале стоит корневой фрейм ФР1 с ^1 = 1, затем следуют остальные фреймы в порядке возрастания их wi

(wi > wi_l). Аналогичным образом располагаются слоты внутри каждого фрейма, так что каждый

слот имеет свое место внутри своего фрейма. Полученная структура образует дерево важности разделов (ДВР) ПрО и их терминов с главным разделом в корне.

Открывая окно интерфейса СПКПЗ, ПА видит на экране ДВР, из которого он может выбрать любую комбинацию разделов и терминов ПрО, задать условия (значения определенных заданных им терминов) и получить результат (значения искомых терминов).

Задача создания ФР с точки зрения базы данных может быть решена с помощью виртуальных таблиц - тематических представлений (ТетаУ1еш). Каждое ТетаУ1еш представляет один из

фреймов ФрМод, а его атрибуты - это слоты ФрМод. Содержимое ТетаУіеш динамически вычисляется на основании данных, находящихся в таблицах РелМод:

ТетаУіеш создаются по определенным правилам, включающим:

• правило наименований (кодировки);

• правило нумерации;

• правило соединения.

Правило наименований позволяет идентифицировать ТетаУіеш на уровне объектов БД, на которых основывается программное приложение.

Правило нумерации ТетаУіеш дает возможнсть построить ДВР в интерфейсе пользователя.

Правило соединения ТетаУіеш используется для определения объема информации, получаемой ПА по запросу. Поскольку соединение ТетаУіеш производится автоматически (программно), то ТетаУіеш должны иметь общий ключ (состоящий из одного или нескольких атрибутов). Таким ключом (Ю) может служить первичный ключ таблицы фактов РелМод.

Рассмотрим две схемы соединения ТетаУіеш: последовательную и иерархическую.

Последовательная схема соединения ТетаУіеш (ТУ) (рис. 3) - это цепь, которая предполагает такое соединение ТетаУіеш по ключу Ю, где каждое последующее ТетаУіеш соединяется с предыдущим.

В результате соединения всех TemaView получается отношение Q, представленное в дизъюнктивной нормальной форме:

m

Q = TV1 x TV2 U TV2 x TV3 U TV3 x TV4 U ... U TVmAxTVm = UTVm-XxTVm , (1)

где конъюнкция TVm-l x TVm - это отношение, содержащее кортежи из декартова произведения отношений TVm-l и TVm, удовлетворяющие условию равенства по общему ключу ID.

Дизъюнкция получается в результате применения операции левого внешнего соединения (left outer join), включающего в результирующее отношение Q кортежи с незаданными атрибутами

правых частей конъюнкций TVm-1 x TVm (с NULL-значениями TVm).

Выражению (1) соответствует следующий оператор Select (по стандарту ANSI SQL 92): Select TV1.A1, TV2 A2, TV3.A3,..., TVm.Am.

From TV1 left outer join TV2 on TV1.ID = TV2.ID left outer join TV3 on TV2.ID = TV3.ID left outer join TV4 on TV3.ID = TV4.ID ... left outer join TVm on TVm-1.ID = TVm.ID.

Результат соединения Q1 представляет собой множество кортежей декартова произведения атрибутов ТетаУ1еш, описывающих ФР и их термины, выбранные ПА.

Недостатком этой схемы является тот факт, что отсутствие данных в каком-либо из ТетаУ1еш приводит к разрыву цепи и недоступности оставшейся правой части, то есть данные из всех ТетаУ1еш, стоящих правее, не будут выбраны.

Поскольку ПА должен иметь возможность выбора любых (всех) кортежей из ТБД, целесообразно использовать иерархическую схему соединения ТетаУ1еш, в которой все ТетаУ1еш соединены с одним главным ТетаУ1еш по ключу Ю. Эта схема представляет собой ориентированный граф О - веер, состоящий из главной корневой вершины степени т -1 и т -1 висячих вершин (листьев) степени 1 (где т - количество ТетаУ1еш) (рис. 4).

Рис. 4. Иерархическая схема соединения

О - это двудольный граф, моделирующий отношения между главным ТетаУіеш - ТУХ (корневым фреймом, общим разделом ПрО) и остальными ТетаУіеш (фреймами, разделами). Если ТБД содержит данные, то ТУХ также будет непустым. Поскольку вершинное покрытие (минимальное число вершин, соединенных со всеми другими вершинами) такого графа равно 1, то можно утверждать, что он представляет наилучший вариант представления структуры ПрО для СПКПЗ, так как дает возможность относительно легко получать данные их всех ТетаУіеш, соединенных с

общей вершиной ТУХ. Ребрами графа О является общий ключ Ю, с помощью которого соединяются все ТетаУіеш.

Добавление нового ФР или удаление существующего ФР в интерфейсе пользователя - это добавление новой вершины в граф О или удаление существующей. Эта операция выполняется администратором путем создания или удаления соответствующего ТетаУіеш и не влияет на работу ПА.

Результат соединения - отношение Q в дизъюнктивной нормальной форме имеет вид

Q = щ x TV2 U TV x TV3 U TV1 x TV4 U ... U TV 1xTVm = U TV1 xTVm

(2)

Дизъюнкция получается в результате применения операции левого внешнего соединения (left outer join), включающего в результирующее отношение Q кортежи с незаданными атрибутами

правых частей конъюнкций 7V1 x TVm (NULL-значения TVm).

2

Выражению (2) соответствует следующий оператор Select (по стандарту ANSI SQL 92): Select TV1.A1, TV2 A2, TV3.A3,., TVm.Am.

From TV1 left outer join TV2 on TV1.ID=TV2.ID left outer join TV3 on TV1.ID=TV3.ID ... left outer join TVm on TV1.ID=TVm.ID.

Применение операции левого внешнего соединения left outer join позволяет создать конструкцию логического «ИЛИ», при этом отсутствие данных в любом из TV не приводит к недоступности оставшейся части, как в последовательной схеме, и не ведет к искажению результирующего отношения (подразумевается, что в непустой БД главное TemaView - TV1 всегда содержит информацию). Иерархическая схема соединения TemaView позволяет получить результирующее отношение Q в виде множества кортежей декартова произведения отношений TV1 и TVm, удовлетворяющих условию равенства по общему ключу ID без потери информации и без избыточности. В этом заключается преимущество иерархической схемы по сравнению с последовательной.

5. Модель бизнес-правил КПЗ

iНе можете найти то, что вам нужно? Попробуйте сервис подбора литературы.

Отношение Q, полученное в результате соединения TemaView (2), представляет собой исходное отношение, с которым будет работать ПА, выбирая атрибуты (слоты отдельных фреймов) и накладывая ограничения или применяя предопределенные функции, заданные моделью бизнес-правил [4].

Модель бизнес-правил БПрМод описывает правила, которым подчиняются значения слотов (терминов) ПрО, соединяя каждый слот ФрМод с определенным набором правил. Она включает

БПрМод ={БПр, СЛ}, где БПр={>, <, =, in, not in, like, %, функция, ...} - множество бизнес-правил;

СЛ - множество слотов (терминов разделов ПрО).

Открывая окно интерфейса, где отображена фреймовая модель ПрО, ПА выполняет следующие операции:

1. Операция выбора слотов. Этой операции соответствует реляционная операция проекции

п [3]:

Qn = пA1,A2,...Am (Q) ,

где Qn - отношение, полученное в результате применения операции проекции к исходному отношению Q, А м - атрибуты отношения Q (слоты ФР).

2. Операция наложения условий. Этой операции соответствует реляционная операция селекции а :

Qa =aF (Q) ,

где Qa - отношение, полученное в результате применения операции селекции к отношению Qn ;

F - критерий выбора на множестве атрибутов в форме логического выражения, образованного с помощью определенных операндов (констант, имен атрибутов, арифметических операций сравнения, логических операций, аналитических функций), которые представляют собой множество бизнес-правил БПр, разработанных и связанных с каждым слотом таким образом, что каждый слот

имеет свой набор бизнес-правил. В результате применения операций проекции и селекции результирующее отношение Qa будет содержать множество кортежей, удовлетворяющих критерию F , что дает возможность полностью автоматизировать работу ПА в интерфейсе СПКПЗ.

б. Выводы

Предложенная технология создания СПКПЗ может быть использована для построения интеллектуальных пользовательских интерфейсов в СППР, позволяющих расширить возможности ПА по реализации произвольных запросов без необходимости знания структуры ТБД и языка SQL или привлечения администратора.

Из изложенного выше следует, что КПЗ обладают большей функциональностью по сравнению с ПМЗ за счет того, что:

- они позволяют ПА самому создавать запросы к ТБД (а не предлагают перечень заранее созданных запросов);

- имеют большую оперативность по сравнению с ПЗ за счет того, что ПА может работать в рамках фреймовой модели ПрО, где фреймы и слоты (тематические разделы и их термины) систематизированы и расположены в привычном для ПА порядке и для каждого слота имеется свой набор бизнес-правил. То есть часть работы уже выполнена.

Однако нужно отметить, что КПЗ обладают тем недостатком, что ПА не может применять правила выбора слотов и задавать функции, которые не предусмотрены заранее в программе. В этом состоят ограничения КПЗ по сравнению с ПЗ.

СПИСОК ЛИТЕРАТУРЫ

1. Оксанич И.Н. К вопросу реализации произвольных запросов пользователя к тематической базе данных / И.Н. Оксанич // Системи підтримки прийняття рішень. Теорія і практика: зб. доповідей наук.-практ. конф. з міжнар. участю (Київ, 8 червня 2009 р.). - Київ, 2009. - С. 78 - 81.

2. Печенкин И.А. Информационные технологии на службе разведки. Обзор современных программных средств обеспечения принятия управленческих решений [Электронный ресурс] / И.А. Печенкин. - Режим доступа: http://www. it2b.ru/files/pechenkin.pdf.

3. Райордан Р. Основы реляционных баз данных / Р. Райордан. - М.: Издательско-торговый дом «Русская редакция», 2001. - С. 95 - 101.

4. Muehlen M. Business Process and Business Rule Modeling: A Represebtational Analysis [Електронний ресурс] / M. Muehlen, M. Indulska, G. Kamp. - Режим доступу:

http: // www.bpmresearch.com/download/papers/MIZU.MAIN.GEKA-V0RTE2007-Final.pdf.

Стаття надійшла до редакції 13.10.2009

i Надоели баннеры? Вы всегда можете отключить рекламу.