Научная статья на тему 'Поддержка пользовательских типов данных в параллельной СУБД Омега для МВС-100'

Поддержка пользовательских типов данных в параллельной СУБД Омега для МВС-100 Текст научной статьи по специальности «Компьютерные и информационные науки»

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

Аннотация научной статьи по компьютерным и информационным наукам, автор научной работы — Цымблер Михаил Леонидович

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

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

Похожие темы научных работ по компьютерным и информационным наукам , автор научной работы — Цымблер Михаил Леонидович

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

Текст научной работы на тему «Поддержка пользовательских типов данных в параллельной СУБД Омега для МВС-100»

ПОДДЕРЖКА ПОЛЬЗОВАТЕЛЬСКИХ ТИПОВ ДАННЫХ В ПАРАЛЛЕЛЬНОЙ СУБД ОМЕГА ДЛЯ МВС-100*

М.Л. Цымблер

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

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

1. Введение

В настоящее время реляционные системы управления базами данных (СУБД) играют доминирующую роль на рынке программного обеспечения систем баз данных [1]. В рамках реляционной модели данных [2] база данных рассматривается как набор взаимосвязанных отношений (таблиц). Каждое значение в ячейке таблицы должно иметь скалярный тип.

Современные реляционные СУБД предоставляют пользователю довольно большой набор встроенных типов данных (например, целые

* Работа выполнена при финансовой поддержке Российского фонда фундаментальных исследований (гранты Л*4 00-07-90077, 02-07-06027).

и вещественные числа, символьные строки, даты) и соответствующих операций над экземплярами этих типов (например, арифметические операции над числами, конкатенация строк, сравнение и другие операции с датами). Однако предоставляемый набор типов данных может быть неадекватным для ряда нетрадиционных приложений баз данных [1]. Необходимый пользователю тип данных может либо отсутствовать в наборе встроенных типов, либо иметь семантику, неприемлемую для приложения. Например, в приложениях географических баз данных, как правило, требуется тип данных “Прямоугольник” и операции “Пересечение”, “Расстояние”, “Вложение”, Другим примером может быть приложение, в котором тип "Дата"отличаетея от стандартного тем, что каждый месяц года состоит из 30 дней.

Указанная проблема определяет задачу разработки средств поддержки пользовательских типов данных и функций эффективной реализации операций этих типов как одну из важных задач для СУБД нового поколения [3].

Согласно [4], СУБД, поддерживающая расширение набора встроенных типов данных, должна предоставлять пользователю средства определения новых типов данных и операций над ними и обеспечивать оптимизацию запросов к данным новых типов,

В настоящей работе мы рассмотрим подход к определению новых типов данных и операций над этими типами, примененный при разработке менеджера типов данных для параллельной СУБД Омега для отечественной мультипроцессорной вычислительной системы МВС-100 [5].

2. Менеджер типов данных в СУБД Омега

В иерархии подсистем СУБД Омега менеджер типов данных занимает следующий, более высокий уровень, чем система управления файлами (СУФ) [6]. СУФ поддерживает понятие файла как набора записей фиксированной длины. Запись состоит из системного заголовка, имеющего структуру, и определяемого пользователем информационного поля, которое представляет собой массив байтов, не имеющий структуры. Основная функция менеджера типов — поддержка, понятия типа данных для определения структуры информационного поля записи файла.

В этом разделе мы сначала перечислим концепции и принципы, которые были использованы при проектировании менеджера типов данных СУБД Омега, а затем опишем интерфейс и схему реализации данной подсистемы,

2.1. Базовые концепции

Классический подход к поддержке типов данных основывается на теории структурной организации данных Хоара [7], где тип определяет класс значений, которые могут принимать переменная или выражение, а набор рассматриваемых типов ограничивается типами, используемыми в математике (множества, последовательности и др.). При проектировании менеджера типов СУБД Омега мы используем концепцию абстрактного типа данных [8]. Абстрактный тип данных (АТД) определяет не только класс допустимых значений экземпляров данного типа, но также набор допустимых операций над экземплярами данного типа, В определение АТД, в частности, входят внешнее представление (имя типа, имена допустимых операций, их аргументов и т.п.) и абстрактное описание операций на некотором языке спецификаций. Концепция АТД нашла конструктивное воплощение в языках программирования СЫ1 [9] и А1рЬагс1 [10].

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

При проектировании менеджера типов СУБД Омега мы также используем концепцию инкапсулированного типа данных [8]. Инкапсулированный тип данных предусматривает защиту описания его операций от внешнего воздействия, то есть пользователь данного типа имеет доступ только к тем объектам, которые указаны во внешнем представлении данного типа.

Менеджер типов данных СУБД Омега рассматривает любой тип данных как инкапсулированный абстрактный тип данных. Менеджер типов предоставляет пользователю функции для определения внеш-

него представления и операций типа данных.

Система 'типов, поддерживаемых СУБД Омега, строится следующим образом. Менеджер типов предоставляет конечное множество стандартных типов данных. Стандартный тип — один из типов данных, определенных в языке баз данных SQL92 [11] , Внешнее представление и операции стандартного типа данных предопределены, В настоящее время менеджер типов данных СУБД Омега поддерживает в качестве стандартных типы CHAR и INTEGER, В дальнейшем множество стандартных типов может быть расширено. Прикладной программист с помощью функций менеджера типов определяет внешнее представление и операции пользовательских 'типов на базе стандартных и ранее определенных пользовательских типов.

Далее мы покажем, как формально определяются внешнее представление и операции пользовательского типа данных,

2.2. Внешнее представление типа данных

Пусть имеется непустое множество В = {I]. Г-,....Г„, }•. элемен-

ты которого — стандартные и ранее определенные пользовательские типы. Множество В назовем базисом для построения нового пользовательского типа.

Пусть имеется также непустое множество N = {1\. !’■>....../',}•.

элементы которого — символьные строки. Натуральное п определяется пользователем. Множество N содержит имена свойств нового пользовательского типа (см, ниже).

Тогда пользовательский тип — это множество троек U = {< % :

Рг ■ Тг >} i£l...n, где I) (г X. Г; (г Н. II г, данном множестве все Pi

различны, а соответствующие им I) не обязательно различны.

При этом тройка < % : Pi : Tj > называется г-м свойством, типа,

Pi называется именем г-го свойства, а 2] — 'типом %-го свойства.

Частным случаем пользовательского типа является тип список, определяемый как пользовательский тип, базис которого состоит в точности из одного элемента. Экземпляр пользовательского типа U -это множество троек {< i ■. Pi ■. Vi >}iei..„, где Vi есть значение i-го свойства типа U. Если Е - экземпляр пользовательского типа, то запись означает значение г-го свойства экземпляра Е.

Таблица 1

Примеры построения пользовательских типов данных

№ шага Имя типа Базис Свойства типа

1 Дата {INTEGER} {<1 :“Год” : 1ХТКСКН . <2 :“Мееяц” : 1ХТКСКН . <3 : “День”: 1ХТКСКН }

2 ФИО {CHAR} {<1 : “Фамилия” : СНЛН . <2 : “Имя” : СНЛН . <3 : “Отчество” : СНЛН }

3 Персона {INTEGER, CHAR, Дата, ФИО} {<1 : “Ф.И.О.” : ФИО>, <2 : “Дата рождения” : Дача . <3 : “Пол” : СНЛН’ . 1 : “Число детей” : IX ТИСКИ )

Следует отметить, что пользовательский тип {<1 : “День” : IX-ТКСКН . 2 : “Месяц” : 1ХТКСКН . <3 : “Год”: 1ХТКСКН }. со-

гласно данному нами определению, не является идентичным типу Дата,

2.3. Операции типа данных

Для работы с экземплярами пользовательского типа данных мы предусматриваем стандартные и пользовательские операции, К стандартным мы относим следующие минимально необходимые при работе с записями файла операции: перевод экземпляра указанного типа в символьную строку и сравнение двух экземпляров одного и того же типа, К пользовательским мы относим все остальные операции типа данных, которые задаются пользователем с помощью специальной нотации. Описание пользовательской операции интерпретируется менеджером типов и сохраняется в базе данных, обеспечивая персистентность типа. Ниже мы дадим определения стандартных операций и опишем нотацию для задания пользовательских операций типа.

2.3.1. Стандартные операции типа данных

Введем отношение порядка между экземплярами пользовательского типа данных следующим образом. Отношение порядка для экземпляров стандартных типов существует по определению (числа, символьные строки и значения прочих стандартных типов сравниваются обычным образом).

Пусть и ={<1:1 : I) > }-(, - пользовательский тип с базисом

В, Е1 и Е2 — экземпляры типа II. Тогда Е1 > Е2, если либо El.Pi > E2.Pi, либо Бк Е 1..п V/ < к El.Fi = E2.Fi и Е1.Рк > Е2.Рк; Е1 = Е2, если для всех г е 1..п El.Fi = к.2.1’,: иначе Е1 < Е2. При этом для каждого пользовательского типа ’/} е В отношение порядка вводится аналогичным образом.

Операция сравнения Сотраге(Т, Е1, Е2) экземпляров Е1 и Е2 типа Т определяется нами как целочисленная функция, которая возвращает 1, если Е1 > Е2, 0, если Е1 = Е2, и -1 в случае, если Е1 < Е2.

Примеры выполнения операции сравнения экземпляров пользовательского типа данных приведены в табл. 2,

Определим теперь операцию перевода экземпляра типа в символьную строку. Пусть функция ТоСкьаг(Т, Е,с1) возвращает результат преобразования экземпляра Е типа Т в символьную строку, где значения свойств разделяются символьной строкой с?. Пусть функция Сопса^Б 1, 52,..., 5„) возвращает символьную строку, которая представляет собой сцепление СИМВОЛЬНЫХ строк , >^2,..., Бп в порядке

их перечисления.

Для экземпляров стандартных типов результат функции ТоСИаг известен по определению (числа, символьные строки и значения прочих стандартных типов преобразуются в символьную строку обычным образом),

Пусть и ={<1:1 : I) >}-(. - пользовательский тип с

базовым множеством В, Е - экземпляр типа II. Тогда операция преобразования экземпляра Е типа Т в символьную строку определяется следующим образом:

ТоСкаг{и, Е,д) = Сопс^{ТоСкаг{Т1,Е.Р1,д),<1,

ТоСкаг{Т2, Е.Р2, с1),...,й, ТоСкаг{Тп, Е.Рп, с!)).

При этом для каждого значения свойства 111). имеющего поль-

зовательский тип I) £ В, результат функции ТоСИаг определяется аналогичным образом.

Примеры выполнения операции преобразования экземпляра пользовательского типа данных в символьную строку приведены в табл. 3,

2.3.2. Пользовательские операции типа данных

Для поддержки пользовательских операций типа данных в реляционной СУБД обычно используется следующий подход [4]. Описание

Таблица 2

Примеры выполнения стандартной операции сравнения экземпляров

Имя типа Операнд 1

Операнд 2

Compare

Дата {<1 :"Го. Г' : 1970 .

<2 :“Месяц” : 12 .

<3 : “День”: 15 >} ФИО {<1 : “Фамилия”

: Пианов . <2 :

“Имя": Пиан . <3 :

“Отчество": Петрович^

Персона {<1 : “Ф.И.О.” :

{<1 : “Фамилия”

: Пианов . <2 :

“Имя” : Пиан . <3 : “Отчество” : 11накопим } . <2 : “Дата рождения” : {<1 :"Го. Г : 1970 . <2

:“Мееяц” : 12 . <3 : “День”: 15 } >, <3 : “Пол” : МУЖ . <4 : “Число детей” : 3>}

{<1 :“Год” : 1970>, <2 :“Мееяц” : 12 .

<3 : “День”: 15 } {<1 : “Фамилия” :

Пианов . <2 : “Имя” : Иван . <3 : “Отчество” : Иванович }

{<1 : “Ф.И.О.” : {<1 : “Фамилия” : Иванов . <2 : “Имя”

: Иван . <3 : “Отчество” : Ивано-

вич } . <2 : “Дата рождения” : {<1 :"Го. Г : 1970 . <2

:“Мееяц” : 12 . <3 “День”: 15 } >, <3 “Пол” : МУЖ . <4 “Число детей” : 0 }

0

Таблица 3

Примеры выполнения стандартной операции преобразования

экземпляра в строку

Имя типа Разделитель Операнд

ToChar

Дата

Дата

ФИО

Персона

а I!

BLANK

(пробел)

{<1 :“Год” : 1970>, <2 :“Месяц” : 12 .

<3 : “День”: 15>} {<1 :“Год” : 1970>, <2 :“Месяц” : 12 .

<3 : “День”: 15>} {<1 : “Фамилия” :

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

Пианов . <2 : “Имя” : Пиан . <3 : “Отчество” : Пваноннч } {<1 : “Ф.И.О.” : {<1 : “Фамилия” : Иванов . <2 : “Имя”

: Иван . <3 : “Отчество” : Ивано-

вич } . <2 : “Дата рождения” : {<1 :“Год” : 1970 . <2

:“Мееяц” : 12 . <3 “День”: 1 ."> } >, <3 “Пол” : МУЖ . <4 “Число детей” : 3 }

1970-12-15

1970.12.15

Иванов Иван Иванович

Иванов, Иван, Иванович, 15,

12, 1970, МУЖ,

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

Выход за рамки СУБД в определении реализации пользовательской операции приводит к тому, что СУБД не может гарантировать целостность данных указанного пользовательского типа, поскольку пользователь сам отвечает за отсутствие синтаксических и логических ошибок в исходном тексте реализации. Кроме того, использование внешнего компилятора при выполнении пользовательской операции может привести к большим накладным расходам: компилятор является продуктом сторонней команды разработчиков и, как правило, не учитывает аппаратно-программные особенности СУБД,

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

В СУБД встраивается интерпретатор описания операций. Интерпретатор — это языковый процессор, который последовательно выполняет программу на исходном языке, в отличие от компилятора, создающего исполняемый код данной программы [12]. В нашем случае под выполнением описания операции мы понимаем синтаксический разбор этого описания, создающий такую конечную цепочку атомов [12], которую мы можем сохранить в вышеуказанных таблицах словаря базы данных без изменения структуры этих таблиц. При выполнении пользовательской операции СУБД последовательно выполняет каждый атом цепочки синтаксического разбора этой операции, осуществляя поиск в соответствующих таблицах словаря базы данных. Использование интерпретатора позволит СУБД контролировать целостность данных пользовательского типа и снизить накладные расходы при выполнении пользовательской операции, однако требует адекватной нотации для описания этой операции. Для описания пользовательской операции типа данных предлагается функциональ-

нал нотация, синтаксис которой схож с одним из функциональных языков программирования. Функциональная парадигма программирования [13] рассматривает программу как процесс вычисления значения математических функций. Значение данных функций определяется лишь их аргументами, а не контекстом выполнения. Кроме того, порядок вычисления выражений, задающих математические функции, управляется рекурсивными и условными выражениями, а не итеративным повторением и последовательностью выполнения операторов, как в нефункциональных языках программирования, например в Си, Для данной нотации является существенным требование сохранения результатов синтаксического разбора описания операции в таблицах словаря базы данных, В частности, максимальное количество фактических параметров в операторе вызова функции должно быть ограничено некоторой константой, поскольку таблицы словаря базы данных, сохраняющие атомы синтаксического разбора, должны иметь аналогичное число столбцов.

Таким образом, мы определяем описание пользовательской операции типа данных как последовательность операторов вызова подпрограммы, Подпрограмма в данном случае — это функция, возвращающая результат стандартного типа. Функция может быть зарезервированной или пользовательской (ранее определенной пользовательской операцией типа данных). На зарезервированные и пользовательские функции накладываются следующие ограничения:

1, Количество формальных параметров функции не превышает заранее фиксированного числа. Количество параметров функции является параметром компиляции менеджера типов данных СУБД Омега, В настоящей реализации менеджера типов максимальное количество параметров функции равно двум,

2, При вызове функции в качестве ее параметра может фигурировать переменная, значение или вложенный вызов другой функции, При этом уровень вложенности вызовов функций не превышает заранее фиксированного числа. Уровень вложенности вызовов функций является параметром компиляции менеджера типов, В настоящей реализации менеджера типов максимальный уровень вложенности вызовов функций равен двум.

3. Все фактические параметры передаются в функцию по ссылке, то есть все изменения формального параметра функции происходят непосредственно над фактическим параметром [13].

4. Функция не может быть рекурсивной, то есть не должна содержать вызовы самой себя.

5. Типы формальных и фактических параметров функции должны совпадать. Соответствие между формальными и фактическими параметрами функции позиционное.

Ниже приведен пример описания пользовательской операции типа данных. В данном случае тип данных — пользовательский тип “Дата”, в котором каждый месяц года состоит из 30 дней, а операция — добавление дней к дате.

INCDAYS(DATE D, INTEGER Days) RETURN INTEGER

BEGIN

ADD(Days, MUL(D.YEAR, 360)); /* Дни:=Дни+Д.Год*360 */

ADD(Days, MUL(D.MONTH, 30));

ADD(Days, D.DAY);

MOV(D.YEAR, DIV(Days, 360)); /* Д.Год:=Дни/360 */

SUB(Days, MUL(D.YEAR, 360)); /* Дни:=Дни - Д.Год*360 */

MOV(D.MONTH, DIV(Days, 30));

SUB(Days, MUL(D.MONTH, 30));

MOV(D.DAY, Days);

RET(l);

END INCDAYS

3. Заключение

В статье был представлен подход к поддержке пользовательских типов данных в реляционной СУБД. Данный подход базируется на концепциях абстрактного и инкапсулированного типов данных. В соответствии с этим тип данных рассматривается как совокупность внешнего представления экземпляров данного типа и набора операций над экземплярами данного типа. Система поддерживаемых типов

данных строится как объединение множества стандартных и пользовательских типов. Множество стандартных типов фиксировано и состоит из типов, определенных в языке баз данных SQL, Пользовательский тип строится на базе стандартных и ранее определенных пользовательских типов. Внешним представлением пользовательского типа является последовательность стандартных и ранее определенных пользовательских типов. Описание пользовательской операции задается с помощью специальной нотации. Пользовательская операция рассматривается как функция, которая возвращает результат стандартного типа данных и состоит из операторов вызова стандартных и ранее определенных пользовательских операций, СУБД интерпретирует описание и сохраняет результат интерпретации в словаре базы данных, обеспечивая персистентность нового пользовательского типа. Данный подход был реализован при разработке менеджера типов данных параллельной СУБД Омега для отечественного многопроцессорного вычислительного комплекса МВС- 100,

Список литературы

1. Когаловский М.Р. Энциклопедия технологий баз данных. М.: Финансы и статистика, 2002. 800 с.

2. Дейт К. Дж. Введение в системы баз данных. 7-е изд. М.: Вильямс, 2001. 1072 с.

3. Зильбершатц А., Стоунбрейкер М., Ульман Д. Базы данных: достижения и перспективы на пороге 21-го столетия // СУБД. 1996.

№ 3. С. 103-117.

4. Stonebraker М. Inclusion of New Types in Relational Data Base Systems // ICDE 1986: Proc. of the Second Int. Conf. on Data Engineering, February 5-7, 1986, Los Angeles, CA, USA. IEEE Comput. Soc. Press, 1986.

P. 262-269.

5. Соколинский Л.Б., Цымблер М.Л. Проект создания параллельной СУБД Омега на базе суперкомпьютера МВС-100/1000 // Телемати-ка’98: Тез. докл. Всерос. науч.-метод, конф. (7-10 июня 1998 г., Санкт-Петербург). СПб.: Вузтелекомцентр, 1998. С. 154-155.

6. Соколинский Л.Б., Цымблер М.Л. Принципы реализации системы управления файлами в параллельной СУБД Омега для МВС-100 // Вестн. Челяб. ун-та. Сер. 3. Математика, механика, информатика. 1999. № 2(5). С. 176-199.

7. Дал У., Дейкстра Э., Хоар К. Структурное программирование. М.:

Мир, 1975. С. 98-197.

8. Агафонов В.Н. Типы и абстракция данных в языках программирования (обзор) // Данные в языках программирования. М.: Мир, 1982.

С. 265-327.

9. Liskov В. Introduction to CLU // New Directions in Programming Languages. IRIA, 1975. P. 139-156.

10. Wulf W., London R., Shaw M. An Introduction to the Construction and Verification of Alphard programs // IEEE Trans., SE-2, 1976. № 4.

P. 253-265.

11. Date C.J., Darwen H. A Guide to the SQL Standard. Reading, Mass.: Addison-Wesley, 1993.

12. Льюис Ф., Розенкранц Д., Стирнз Р. Теоретические основы проектирования компиляторов. М.: Мир, 1979. 655 с.

13. Себеста Р. Основные концепции языков программирования. М.: Вильямс, 2001. 672 с.

Челябинский государственный университет, mzvm@csu.ru

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