Электронная база данных и способ её формирования

Изобретение относится к области обработки данных. Техническим результатом является повышение надежности базы данных за счет исключения ошибок при добавлении новых данных и формировании запросов и отчетов, а также снижения риска лавинообразной деградации производительности из-за отсутствия необходимых индексов при работе с большими объемами данных. В способе формирования электронной базы данных данные организуют в единственную таблицу. Формируют строки, отображающие корневой элемент, тип данных, термин, реквизит термина и данные. Сохраняют первый идентификационный номер, уникальный идентификационный номер типа данных, отличающийся от первого идентификационного номера, наименование используемого типа данных, код типа данных, уникальный идентификационный номер термина, наименование термина, код используемого типа данных, уникальный идентификационный номер реквизита термина, идентификационный номер родительского элемента реквизита термина, зависящего от родительского элемента, уникальный идентификационный номер данных, идентификационный номер родительского элемента, данные, зависящие от родительского элемента, и уникальный код типа данных. 1 з.п. ф-лы, 8 ил., 3 табл.

 

ОБЛАСТЬ ТЕХНИКИ

Группа изобретений относится к области обработки данных, а именно к электронной базе данных и способу формирования электронной базы данных.

УРОВЕНЬ ТЕХНИКИ

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

СУЩНОСТЬ

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

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

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

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

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

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

В некоторых реализациях единственная таблица дополнительно содержит пятый столбец для хранения порядковых номеров элементов среди равных по подчиненности.

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

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

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

Универсальность (многоплановость) заявляемой системы электронной базы данных с использованием Web-интерфейса позволяет скрыть от пользователя все технические детали базы данных и внутренних алгоритмов работы с данными и предоставить ему возможность работать с моделью данных на понятном ему языке: все объекты предметной области и действия над ними описываются без использования прикладного программирования, что также способствует наряду с повышением удобства использования повышению надежности системы.

В заявляемой электронной базе данных все данные хранятся в единственной таблице, состоящей из пяти столбцов. Эти пять столбцов - достаточный набор для построения любой структуры данных, определяющий все признаки единицы информации: идентификатор (физическое расположение), тип, родитель, значение и порядок (среди элементов этого типа у этого родителя). Первый столбец содержит идентификационные номера элементов базы данных (ID), второй - идентификационные номера родительских элементов для элементов, находящихся в подчиненной зависимости от других элементов (Parent ID), третий - значения элементов (Value), четвертый - код описанной в этой же таблице записи, используемый в качестве типа данного элемента (Type), пятый - порядковые номера элементов среди равных по подчиненности (Order).

Пятый столбец (Order) является дополнительным и служит для упорядочивания выборки по запросу пользователя.

Индексы, построенные для таблицы:

PRIMARY (ID) - уникальный индекс (первичный ключ);

Туре + Value - тип и значение для индексированного поиска по значению;

Parent ID + Type - идентификационный номер родительского элемента и код типа элемента для поиска реквизитов элемента с использованием индекса.

Для высоконагруженных систем полезно построить еще один индекс: Туре + ID - код типа элемента и идентификационный номер для ускоренного доступа к определенному типу данных.

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

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

Определение данных, взаимосвязи и подчиненности хранятся в виде метаданных в той же таблице, где и сами данные.

Каждый элемент (единица данных) занимает как минимум одну строку таблицы, в которую записаны его идентификационный номер, идентификационный номер родительского объекта, тип данных и значение (данные). Значение хранится в виде набора символов порциями ограниченной длины, например, 127 символов. В случае, когда размер поля в третьем столбце Value недостаточен для хранения значения элемента, оставшаяся часть этого значения записывается в подчиненные элементы - строки, пронумерованные по порядку заполнения в поле пятого столбца Order. Такие строки имеют специальный тип Type, равный 0, который не описан в метаданных, но активно используется в заявляемой базе данных. В случае отсутствия пятого столбца Order очередность следования фрагментов значений элементов в третьем столбце Value определяется очередностью их идентификационных номеров (ID).

Метаданные подчинены несуществующему элементу с ID=0, независимые элементы (объекты) подчинены корневому элементу с ID=1.

Метаданные описывают структуру данных, и в соответствии с этой структурой СУБД создает, хранит и обрабатывает элементы данных.

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

Пример набора базовых типов данных показан в Таблице 2.

Базовые типы данных используются как метаданные и идентифицируются по полю в третьем столбце Value. Запись метаданных для определения типа содержит в четвертом столбце Type идентификатор базового типа или свой собственный в случае, когда эта запись сама описывает базовый тип.

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

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

Пример описания метаданных и данных в базе данных показан в Таблице 3.

Способ реализуют следующим образом.

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

Затем во второй и последующей строках указывают базовые типы данных, присваивая в первом столбце ID уникальный идентификационный номер. Значениям ячеек второго столбца Parent ID присваивают нулевое значение, т.к. элементы типов данных не имеют родительских элементов. В ячейках третьего столбца Value указывают наименования типов данных. В ячейках четвертого столбца Туре базовым типам данных присваивают их же ID - базовые типы ссылаются сами на себя в качестве типа. Значениям ячеек пятого столбца Order присваивают также нулевое значение в связи с независимостью данных элементов и отсутствием порядка подчиненности.

В последующих строках описывают термины, используемые пользователем для описания данных. Термин может определять ссылку на другой зарегистрированный ранее термин. В ячейках первого столбца ID указывают уникальные идентификационные номера терминов. В ячейках второго столбца Parent ID указывают нулевое значение. В ячейках третьего столбца Value указывают названия терминов или оставляют его пустым в случае, когда этот термин является ссылкой на другой термин. В ячейках четвертого столбца Туре терминам присваивают код типа данного термина - ID базового типа или ID другого описанного ранее термина в случае, когда этот термин является ссылкой на другой термин. Ячейкам пятого столбца Order присваивают нулевое значение.

В соответствие терминам описывают зависимые от них реквизиты - параметры или свойства терминов, используемые пользователем для описания данных. В ячейках первого столбца ID указывают уникальные идентификационные номера реквизитов. В ячейках второго столбца Parent ID указывают идентификационные номера родительских терминов. В ячейках третьего столбца Value может храниться дополнительная служебная информация, например, значение по умолчанию для этого реквизита, признак обязательности его наличия или маска для проверки его валидности. В ячейках четвертого столбца Type указывают тип реквизита - ID описанного ранее элемента для идентификации назначения и свойств данного термина. Ячейкам пятого столбца Order присваивают численное значение порядка подчиненности среди других равнозначных реквизитов термина.

Затем описывают непосредственно данные, содержащие смысловую информацию для пользователя и которые будут служить наполнением для отчетов при обработке запросов пользователя. В ячейках первого столбца ID указывают уникальные идентификационные номера единиц данных. В ячейках второго столбца Parent ID указывают идентификационный номер корневого элемента либо родительских терминов при их наличии. В ячейках третьего столбца Value указывают значения данных. В ячейках четвертого столбца Туре указывают ID типа данных, определяющего свойства этой конкретной записи. Ячейкам пятого столбца Order присваивают численные значения порядка подчиненности данных при наличии нескольких равнозначных элементов, подчиненных другому одному элементу данных.

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

В контексте данного описания, SQL (structured query language) - формальный непроцедурный язык программирования, применяемый для создания, модификации и управления данными в произвольной реляционной базе данных, управляемой соответствующей системой управления базами данных (СУБД).

В контексте данного описания MySQL свободная реляционная система управления базами данных (СУБД).

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

В контексте данного описания база данных - представленная в объективной форме совокупность самостоятельных данных.

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

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

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

В контексте данного описания, «сервер» представляет собой компьютерную программу, которая работает на соответствующем оборудовании и способна принимать запросы (например, от электронных устройств) по сети и выполнять эти запросы или вызывать эти запросы для исполнения. Оборудование может быть представлять собой один физический компьютер или одну физическую компьютерную систему, однако это не обязательно в отношении заявляемой группы изобретений. В данном контексте использование выражения «сервер» не означает, что каждая задача (например, полученные инструкции или запросы) или какая-либо конкретная задача будет получена, выполнена или повлекла за собой выполнение таким сервером (т.е. таким программным обеспечением и/или оборудованием). Это означает, что любое количество программных или аппаратных устройств может участвовать в приеме/отправке, выполнении или послужить причиной выполнения любой задачи или запроса или последствий любой задачи или запроса. И все это программное и аппаратное обеспечение может быть одним сервером или несколькими серверами, которые включены в выражение «по крайней мере один сервер».

В контексте данного описания «электронное устройство» представляет собой любое компьютерное оборудование, которое может запускать программное обеспечение для соответствующей задачи. В контексте данного описания термин «электронное устройство» означает, что устройство может функционировать в качестве сервера для других электронных устройств, однако это не обязательно в отношении данного группы изобретений. Таким образом, некоторыми (не ограничивающими) примерами электронных устройств являются персональные компьютеры (настольные компьютеры, ноутбуки, нетбуки и т.д.), смартфоны и планшеты, а также сетевое оборудование, такое как маршрутизаторы, коммутаторы и шлюзы. Следует понимать, что в данном контексте тот факт, что устройство функционирует как электронное устройство, не означает, что оно не может функционировать в качестве сервера для других электронных устройств. Использование выражения «электронное устройство» не исключает использование нескольких электронных устройств при приеме/отправке, выполнении или вызове выполнения какой-либо задачи или запроса или последствий любой задачи или запроса или этапов любого описанного здесь способа.

В контексте данного описания выражение «информация» включает в себя информацию любого характера или вида, которая может быть сохранена в базе данных. Таким образом, информация включает в себя, но не ограничивается указанным перечнем: аудиовизуальные произведения (изображения, фильмы, звуковые записи, презентации и т.д.), данные (данные о местоположении, цифровые данные и т.д.), текст (мнения, комментарии, вопросы, сообщения и т.д.), документы, таблицы и т.д.

В контексте данного описания выражение «программный компонент» означает наличие программного обеспечения (соответствующего конкретному аппаратному оборудованию), которое необходимо и достаточно для достижения конкретной функции (функций), на которую делается ссылка.

В контексте данного описания слова «первый», «второй», «третий» и т.д. использованы в качестве прилагательных только с целью указания различия между существительными, с которыми они связаны, а не для описания какой-либо конкретной связи между этими существительными. Так, например, следует понимать, что использование терминов «первая база данных» и «третий сервер» не подразумевает какого-либо конкретного порядка, типа, хронологии, иерархии или ранжирования, например между серверами. Их использование (само по себе) не подразумевает, что любой «второй сервер» обязательно должен существовать в любой конкретной ситуации. Кроме того, как обсуждается здесь в других контекстах, ссылка на «первый» элемент и «второй» элемент не исключает того, что два элемента являются одним и тем же фактическим элементом реального мира. Таким образом, например, в некоторых случаях «первый» сервер и «второй» сервер могут быть одними и теми же программными и/или аппаратными компонентами, в других случаях они могут быть различными программными и/или аппаратными компонентами.

Реализации заявляемой группы изобретений имеют по меньшей мере один из вышеупомянутых объектов и/или аспектов, но необязательно содержат все из них. Следует понимать, что некоторые аспекты настоящей группы изобретений, которые возникли в результате попыток достичь вышеупомянутого объекта, могут не удовлетворять этому объекту и/или могут удовлетворять другим объектам, не указанным здесь конкретно.

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

КРАТКОЕ ОПИСАНИЕ ИЛЛЮСТРАЦИЙ

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

Фиг. 1 иллюстрирует табличное представление типа индекса и данных в таблице.

Фиг. 2 иллюстрирует табличное представление массива данных «Клиент» и «Встреча».

Фиг. 3 иллюстрирует табличное представление массива данных «Договор».

Фиг. 4 иллюстрирует вид редактора по вкладке «Типы».

Фиг. 5 иллюстрирует соответствие полей редактора полям табличного представления.

Фиг. 6 иллюстрирует форму для формирования отчета.

Фиг. 7 иллюстрирует вид сформированного отчета.

ДЕТАЛЬНОЕ ОПИСАНИЕ ИЛЛЮСТРАЦИЙ

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

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

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

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

На фиг. 1-7 использованы следующие обозначения: 1 - термины, 2 реквизиты и 3 - данные.

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

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

На фиг. 2 и 3 показаны табличные представления массива данных, заполняемых пользователем, на которых «Клиент», «Встречи» и «Договор» являются терминами 1, наименования «Клиент», «Категория», «Телефон», «Дата» и т.д. - реквизитами 2 терминов 1, а в ячейках таблицы указаны сами данные 3.

Основная проблема информационных систем - это растущая цена их поддержки при возрастании сложности системы, причем зачастую затраты на разработку и сопровождение растут экспоненциально (см. Фиг. 8). Два основных фактора риска здесь: несовершенство разработки программного кода и компромисс при выборе архитектуры базы данных. Заявляемая система позволяет пользователю самостоятельно задать сколько угодно сложную структуру данных и правила их обработки без необходимости создания таблиц базы данных, индексов, хранимых процедур и функций, программного кода. Таким образом, нет необходимости обращаться к дорогостоящей команде разработки: аналитик, ведущий разработчик, программист/кодер, тестировщик, внедренец. Заявляемая группа изобретений используют уже готовый программный код и архитектурное решение в виде ограниченного набора примитивных блоков, из которых можно построить информационную систему любой сложности, обеспечивая универсальность системы, в которой зависимость затрат на сопровождение от сложности системы будет не хуже линейной. Это преимущество обеспечивается определенной избыточностью данных, поскольку в ней проиндексированы все хранящиеся данные, и вычислений, однако по стоимости эти затраты намного ниже и материальных затрат на содержание команды разработки. Самый главный риск - человеческий фактор при проектировании и реализации программного кода и базы данных - полностью исключен.

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

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

На фиг. 4 показаны поля редактора справочника типов, позволяющего пользователю задавать типы данных и их реквизиты (свойства), создавая специфическую иерархию данных для каждой конкретной ситуации на основе единственной таблицы заявляемой системы. Пользователь видит все типы, которым обучена система, а также их подчиненности и связи. В частности, он видит, что тип Клиент имеет реквизиты Телефон, Категория и Встречи. При этом Категория - это справочное значение, которое определяется ссылкой на запись в справочнике Категория; Встречи - это подчиненный массив записей. Заявляемая система позволяет представить все это пользователю без раскрытия технических деталей, он оперирует только терминами своего бизнеса и двумя простейшими мнемониками: префикс ссылки на справочник «-->» и базовый тип данных (DATE, CHARS, NUMBER и другие). Достаточный уровень подготовки для работы со справочником типов - это грамотный пользователь Microsoft Excel, что в настоящее время доступно большинству офисных работников.

На фиг. 5 показано соответствие полей редактора типов полям табличного представления. Редактор типов позволяет создать понятное пользователю представление бизнес-сущностей в виде таблиц. Пользователь может настроить порядок колонок в таблице (значок «^» в редакторе типов перемещает реквизит на одну строку выше) и задать обязательные к заполнению реквизиты типа (восклицательный знак в квадратных скобках «[!]» означает, что реквизит обязателен к заполнению). Структура, заданная в редакторе типов, отображается соответствующим образом в таблицах справочника заявляемой системы.

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

Назначение полей таблицы Колонки отчета следующее.

Имя в отчете - название колонки в выводимом отчете, по умолчанию - значение Колонки отчета.

Формула - задает вычисляемое выражение или псевдоним колонки. В выпадающем списке колонок отчета на последней позиции находится значение «Вычисляемое». Это синтетическое поле, которое позволяет вставить произвольные операторы и функции, допустимые в языке SQL. При этом можно оперировать любыми другими колонками отчета, если для них задан псевдоним в их поле Формула.

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

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

Функция - агрегирующая функция, применяемая к значению поля: AVG (среднее), COUNT (количество), МАХ (максимальное), MIN (минимальное), SUM (сумма). Группировка значений, посчитанных этой функцией, происходит по всем полям, в которых не используется агрегирование (не указана одна из перечисленных функций).

Функция (от), Функция (до) - диапазон значений (для дат и чисел) или маска (для текста), применяемые после вычисления функций, указанных в поле Функция (аналог ключа HAVING в SQL). Здесь допускается использовать значение других полей отчета, если заключить их имя из колонки Формула в квадратные скобки.

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

Формат - конечный формат отображения поля. Служит для приведения значения к нужному виду.

Сорт. - указатель последовательности и направления сортировки отчета. Отрицательное число здесь даст обратную сортировку (по убыванию значений).

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

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

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

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

1. Способ формирования электронной базы данных, характеризующийся тем, что способ исполняют с помощью системы управления базой данных посредством электронного устройства по следующим этапам:

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

формируют первую строку, отображающую корневой элемент, в первом столбце которой сохраняют первый идентификационный номер;

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

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

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

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

2. Способ по п. 1, характеризующийся тем, что дополнительно формируют пятый столбец для сохранения порядковых номеров элементов среди элементов, равных по подчиненности.



 

Похожие патенты:
Изобретение относится к средствам визуализации документа. Технический результат заключается в расширении арсенала технических средств визуализации документа.

Изобретение относится к цифровой вычислительной технике и может найти применение для аппаратной реализации. Технический результат заключается в расширении класса реализуемых функций.

Изобретение относится к цифровой вычислительной технике, а именно к цифровым вычислительным системам для обработки входной информации о характеристиках разнородности боевых средств.

Изобретение относится к области радиотехники и может быть использовано в многоканальных цифровых мониторинговых приемниках, реализованных на ПЛИС, в качестве устройства для изменения частоты дискретизации.

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

Изобретение относится к способам определения категории содержимого на основании шаблонов с использованием интерфейса программирования приложений, применяемого при создании приложений для пользователей с ограниченными возможностями.

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

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

Изобретение относится к области обработки открытого интерфейса прикладного программирования (API). Техническим результатом является обработка множества интерфейсов прикладного программирования (API) сервером API.

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

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

Изобретение относится к способам определения категории содержимого на основании шаблонов с использованием интерфейса программирования приложений, применяемого при создании приложений для пользователей с ограниченными возможностями.

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

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

Изобретение относится к области обработки открытого интерфейса прикладного программирования (API). Техническим результатом является обработка множества интерфейсов прикладного программирования (API) сервером API.

Изобретение относится к области обработки открытого интерфейса прикладного программирования (API). Техническим результатом является обработка множества интерфейсов прикладного программирования (API) сервером API.

Изобретение относится к области обработки изображений. Технический результат заключается в обеспечении конвертации без потерь PDF документа в PDF документ с возможностью поиска.

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

Изобретение относится к средствам поиска по видеоконтенту. Технический результат заключается в расширении арсенала технических средств поиска по видео.

Изобретение относится к способу обработки данных, относящихся к соединению с платформой интернет-сайта, сервером. Технический результат заключается в повышение объема и точности получаемой информации. Идентифицируют ситуацию пользователя, подключенного к указанной платформе посредством элемента оборудования, по списку типовых ситуаций, причем каждая типовая ситуация связана с по меньшей мере одной стратегией, каждая стратегия содержит один или более ситуационных движков, выбранных из библиотеки ситуационных движков, и каждый ситуационный движок обладает возможностью выполнения определенной обработки в отношении ситуации пользователя с целью получения сообщения, которое может оказать на ситуацию ожидаемое воздействие. Для по меньшей мере одной из стратегий, связанных с указанной идентифицированной ситуацией, выполняют средствами обработки сервера ситуационные движки указанной стратегии в отношении указанной ситуации с целью получения по меньшей мере одного стека сообщений. Передают в указанный элемент оборудования указанного пользователя и/или платформы подмножества сообщений из указанного по меньшей мере одного стека сообщений. 2 н. и 8 з.п. ф-лы, 6 ил.

Изобретение относится к области обработки данных. Техническим результатом является повышение надежности базы данных за счет исключения ошибок при добавлении новых данных и формировании запросов и отчетов, а также снижения риска лавинообразной деградации производительности из-за отсутствия необходимых индексов при работе с большими объемами данных. В способе формирования электронной базы данных данные организуют в единственную таблицу. Формируют строки, отображающие корневой элемент, тип данных, термин, реквизит термина и данные. Сохраняют первый идентификационный номер, уникальный идентификационный номер типа данных, отличающийся от первого идентификационного номера, наименование используемого типа данных, код типа данных, уникальный идентификационный номер термина, наименование термина, код используемого типа данных, уникальный идентификационный номер реквизита термина, идентификационный номер родительского элемента реквизита термина, зависящего от родительского элемента, уникальный идентификационный номер данных, идентификационный номер родительского элемента, данные, зависящие от родительского элемента, и уникальный код типа данных. 1 з.п. ф-лы, 8 ил., 3 табл.

Наверх