WikiDer > Helix (база данных)

Helix (database)

Спираль это система управления базами данных для Apple Macintosh платформа, созданная в 1983 году. Helix использует графический "язык программирования"добавить логику в свои приложения, позволяя непрограммистам создавать сложные приложения.

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

История

Первоначально созданный Odesta Corporation из Нортбрука, штат Иллинойс, в 1983 году на оригинальном Macintosh, Helix дебютировал и получил восторженные отзывы, когда был впервые выпущен в конце 1984 года.

В то время Mac поддерживал только 440 КБ дискеты как хранилище. Сначала пользователи запускали Helix с дискеты с установленной Helix на «системном диске», на котором Операционная система жили до начала эпохи хранения на жестких дисках. Эта конфигурация оставляла мало места для приложений или данных. Предполагалось, что пользователи добавят вторую дискету для любого вида реального использования, с ОС и Helix на одной дискете, а данными на другой. Несмотря на эти первоначальные ограничения, Helix уже был очень мощным и полностью реляционная база данных которые легко переносились по мере того, как машины становились быстрее и мощнее, а варианты хранения превратились в обширные инструменты, которые сегодня считаются само собой разумеющимся.

В мае 1986 года Одеста освободил Двойная спираль. Основной новый набор функций позволял создавать пользовательские меню и строки меню, в результате чего создавались «автономные» приложения. Для сравнения: исходная Helix создавала приложения, которые явно работали в Helix, во многом как Microsoft Word документ явно работает «внутри Word». Выпущенный как часть более крупного программного обеспечения, пакет Helix также включает автономный время выполнения версия известна как RunTime Helix что позволит пользователям запускать приложения Double Helix без установленной полной версии, а также Многопользовательская спираль который работал в клиент – сервер мода.

Обновление линейки продуктов Helix было непрерывным в течение 1980-х годов, но компания потратила огромное количество времени и денег на разработку версии, известной как Удаленная спираль который запускал базовую систему разработки Helix поверх VAX на основе баз данных. Идея заключалась в том, чтобы предложить Mac-опыт на "большой утюг"системы, распространенная тема в начале 1990-х. Компания также выпустила ряд связанных инструментов, GeoQuery и Стол данных, для анализа баз данных. Однако это было незадолго до того, как средний Mac смог превзойти миникомпьютерпопулярность VAX пошла на убыль, и продукт никогда не пользовался большим успехом.

В 1992 году Odesta распалась, и были выделены оригинальные приложения Helix. Double Helix возродился как Helix Express в Helix Technologies, позиционируется как лидер по производительности, а не как «простой в использовании». К сожалению, материнская компания оказалась втянутой в несвязанную, но дорогостоящую судебную тяжбу, и Helix зачахла. В 1998 году компания Helix Technologies была приобретена компанией Chip Merchant, поставщиком памяти из Сан-Диего, который в 2000 году выпустил крупное обновление, добавив возможности TCP / IP в Helix Client / Server и значительно улучшив производительность всей линейки продуктов. Однако падение цен на память и спад экономики в совокупности привели к банкротству The Chip Merchant в 2002 году, в результате чего Helix оказалась в состоянии правовой неопределенности. Он был куплен в 2004 году двумя людьми, которые занимались его повседневной деятельностью, Гил Нумерофф и Мэтт Стрэнджпри финансовой поддержке неназванного бизнесмена и давнего пользователя Helix, создавая новую компанию: QSA ToolWorks.

QSA пригласила соавтора Helix Ларри Аткин обратно в складку Helix, а затем вернули Стив Кейзер, оригинальный архитектор MultiUser Helix. Названный Команда восстановления Helix, эта новая команда менеджеров и программистов приступила к работе по переписыванию продуктов Classic Helix для работы под управлением Mac OS X. Сервер OS X Helix вместе с тремя встроенными инструментами диагностики и обслуживания был выпущен в декабре 2005 года.

Через месяц Apple анонсировала первые продукты, основанные на их переходе с PowerPC к Intel процессоров, заставляя QSA "переключить передачи" и начать процесс преобразования своего кода в Универсальный двоичный файл формат. Это вызвало преобразование из CodeWarrior IDE к Xcode, после чего они выпустили собственные версии своих трех "конечный пользователь"продукты. Ранние версии (известные как" предварительные версии ") были неполными и нестабильными, но частые обновления (пять только в 2008 году) решали эти проблемы. Еще девять обновлений в 2009 и 2010 годах были направлены на завершение набора функций, устранение оставшихся ошибок и повышение производительности.

В то же время QSA начала работу над переносом Helix IDE (известной как Helix RADE) в OS X. Первоначально анонсированный в декабре 2009 года проект носил кодовое название Европа, как косвенная ссылка на фильм 2010.[1] В июне 2011 года QSA начала поставки ″ Предварительных выпусков ″ - версий с некоторыми, но не всеми функциями, перенесенными на OS X.[2] Перенос функций был завершен в июне 2013 года.[3]

Описание

Проект Helix известен как Коллекция, «документ», созданный Helix RADE (что означает «среда быстрой разработки приложений»). Он представлен в системе своего рода «псевдо-рабочим столом», похожим на Macintosh Finder. Коллекция может содержать тысячи отдельных баз данных (также известных как отношения или таблицы). Приложения Helix открывают одновременно только одну коллекцию. Однако можно приобрести лицензии, чтобы обеспечить одновременный доступ к многочисленным коллекциям, ограниченный в первую очередь доступной памятью.

Открытие коллекции приводит к открытию окна проекта с двумя основными частями, полностью управляемыми уникальным набором GUI объекты. Слева ряд Икона колодцы, представляющий новые объекты, которые могут быть созданы, и прокручиваемое окно справа (известное как Окно коллекции) отображает объекты, созданные пользователем. Иконки перетаскиваются из лунок слева в окно для создания новых объектов в коллекции. Эти объекты включают связи (таблицы) для хранения данных, последовательности (макросы) для автоматизации задач и пользователи для создания пользовательских меню для конечного пользователя. Это одна из самых необычных и мощных функций Helix.

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

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

Helix RADE работает в двух режимах: режиме проектирования и режиме пользователя. В пользовательском режиме коллекция Helix открывается в одной из определенных полос пользовательского меню, что позволяет пользователю использовать базу данных, как любое другое приложение. Режим дизайна позволяет разработчику (или опытному пользователю) изменять дизайн базы данных, добавлять поля, создавать новые отчеты и т. Д.

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

Несмотря на то, что Helix весьма искусен в работе с базами данных малого и среднего размера, общая проблема заключается в том, что на протяжении большей части своего жизненного цикла он работал только в совместная многозадачность среда классической Mac OS, что делает ее нестабильной для больших баз данных. Хотя сам язык программирования имеет масштабируемость требуется для создания сложных баз данных, невозможность надежной работы в 24/7 Среда относит Helix к рабочим группам из 100 или менее пользователей. Однако эти ограничения быстро становятся историей. QSA выпустила версию своего сервера Helix Server для OS X в декабре 2005 года, а остальную часть своей линейки продуктов выпускает в версиях OS X в 2006 и 2007 годах.

Для тех, кто знаком с Helix, экономия времени на разработку может быть значительной. По оценке одного эксперта, который также является ведущим инструктором / разработчиком Microsoft Access, в зависимости от размера проекта проект Helix может быть завершен в 30-70% случаев, как и тот же проект Access. Экономия достигается, в частности, за счет отсутствия «языка» программирования, а значит, устранения всех синтаксических ошибок. Поскольку Helix сама по себе не позволяет разработчику совершать синтаксические или программные ошибки, остальные источники проблем связаны с ошибками в бизнес-логике. Все языки сталкиваются с этой проблемой, но Helix еще раз смягчает трудность отслеживания проблем из-за своей объектной и графической природы. Поскольку все объекты связаны (посредством значков, а не посредством кодирования), система «знает», какие объекты используются другими объектами и каким образом, и упрощает отслеживание ошибок бизнес-логики, а также предоставляет простой метод определения всего, что является собирается затронуть предлагаемое изменение любого объекта.

Ограничения визуального программирования Helix

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

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

С этой целью, когда Helix RADE был обновлен для работы на компьютерах Intel Mac, был добавлен «язык выражений счеты», чтобы предоставить эту возможность тем, кто в ней нуждался.

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

Рекомендации

внешняя ссылка