WikiDer > Apache Empire-db

Apache Empire-db
Apache Empire-db
Apache Empire-db Logo.svg
Разработчики)Фонд программного обеспечения Apache
Стабильный выпуск
2.4.7 / 31 октября 2018 г.; 2 года назад (2018-10-31)
РепозиторийРепозиторий EmpireDB
Написано вЯва
Операционная системаКроссплатформенность
ТипСтруктура настойчивости
ЛицензияЛицензия Apache 2.0
Интернет сайтempire-db.apache.org

Apache Empire-db - это библиотека Java, которая предоставляет объектно-ориентированный API высокого уровня для доступа системы управления реляционными базами данных (СУБД) через JDBC. Apache Empire-db имеет открытый исходный код и предоставляется на условиях Лицензия Apache 2.0 от Фонд программного обеспечения Apache.

В сравнении с Объектно-реляционное отображение (ORM) или другие решения для сохранения данных, такие как Спящий режим, iBATIS или же TopLink Empire-db не использует файлы XML или аннотации Java для отображения простого (старого) объекта Java (POJOs) в таблицы, представления и столбцы базы данных. Вместо этого Empire-db использует объектную модель Java для описания базовой модели данных и API, который работает почти исключительно со ссылками на объекты, а не с строковые литералы.

Целью Empire-db является обеспечение лучшего качества программного обеспечения и улучшенной ремонтопригодности за счет повышения безопасности во время компиляции и уменьшения избыточности метаданных. Кроме того, приложения могут получить лучшую производительность за счет полного контроля над SQL операторов и их выполнение разработчиком по сравнению с большинством решений OR-mapping.

Основные преимущества

Ключевым преимуществом Empire-db является его API для динамической генерации SQL для произвольных операторов выбора, обновления, вставки или удаления исключительно с использованием методов Java, которые ссылаются на объекты модели. Это обеспечивает безопасность типов и почти полностью исключает использование строковых литералов для имен или выражений в коде. Кроме того, независимость СУБД достигается за счет модели подключаемого драйвера.

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

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

Краткий обзор функций

  • Определение модели данных с помощью объектной модели Java исключает необходимость изучения XML-схем или аннотаций и легко допускает перехват и расширения пользователей.
  • Независимая обработка записей и определение команд портативной СУБД с поддержкой различных реляционных баз данных, таких как Oracle, Microsoft SQL Server, MySQL, дерби, H2 и HSQLDB (начиная с версии 2.0.5)
  • Генерация DDL для целевой СУБД из определения объекта либо для всей базы данных, либо для отдельных объектов, таких как таблицы, представления, столбцы и отношения.
  • Типобезопасный API для динамической генерации команд SQL позволяет динамически строить операторы SQL, используя только методы API и ссылки на объекты вместо строковых литералов. Это обеспечивает высокую степень типовой безопасности, что упрощает тестирование и обслуживание.
  • Уменьшенный объем кода Java и мощный перехват доступа к полям и метаданным с помощью динамических bean-компонентов в качестве альтернативы POJO. Это даже позволяет изменять модель данных (DDL) во время выполнения.
  • Автоматическое отслеживание состояния записи и модификации полей (также известная как «грязная проверка») только для вставки / обновления измененных полей.
  • Поддержка оптимистичной блокировки с помощью столбца временных меток.
  • Нет необходимости всегда работать с полными объектами базы данных. Создавайте запросы для предоставления данных точно так, как это необходимо, и получения результата, например, в виде списка любого типа POJO с соответствующими установщиками свойств или конструктором.
  • Легкая и пассивная библиотека с нулевым объемом конфигурации, позволяющая легко интегрироваться с любой архитектурой или платформой.

Пример

В качестве примера рассмотрим базу данных с двумя таблицами с именем Сотрудники и Отделы для которого необходимо получить список сотрудников в определенном формате с определенными ограничениями и заданным порядком.

Предполагается, что соответствующий оператор SQL синтаксиса Oracle имеет следующий вид:

    ВЫБРАТЬ t1.EMPLOYEE_ID,            t1.ФАМИЛИЯ || ', ' || t1.ИМЯ В КАЧЕСТВЕ ИМЯ,            t2.ОТДЕЛЕНИЕ    ИЗ (СОТРУДНИКИ t1           ВНУТРЕННИЙ ПРИСОЕДИНИТЬСЯ ОТДЕЛЕНИЯ t2 НА t1.DEPARTMENT_ID = t2.DEPARTMENT_ID)    КУДА верхний(t1.ФАМИЛИЯ) ПОДОБНО верхний('Foo%')       И t1.НА ПЕНСИИ=0    ПОРЯДОК К t1.ФАМИЛИЯ, t1.ИМЯ

Этот оператор SQL можно создать с помощью командного API Empire-db, используя такие ссылки на объектную модель:

    SampleDB db = getDatabase();    // Объявление ярлыков (не обязательно, но удобно)    SampleDB.Сотрудники EMP = db.СОТРУДНИКИ;    SampleDB.Отделы DEP = db.ОТДЕЛЕНИЯ;    // Создаем командный объект    DBCommand cmd = db.createCommand();    // Выбираем столбцы    cmd.Выбрать(EMP.EMPLOYEE_ID);    cmd.Выбрать(EMP.ФАМИЛИЯ.добавить(", ").добавить(EMP.ИМЯ).в качестве("ИМЯ"));    cmd.Выбрать(DEP.ОТДЕЛЕНИЕ);    // Соединяем таблицы    cmd.присоединиться  (EMP.DEPARTMENT_ID, DEP.DEPARTMENT_ID);    // Устанавливаем ограничения    cmd.куда(EMP.ФАМИЛИЯ.likeUpper("Фу%"));    cmd.куда(EMP.НА ПЕНСИИ.является(ложный));    // Устанавливаем порядок    cmd.Сортировать по(EMP.ФАМИЛИЯ);    cmd.Сортировать по(EMP.ИМЯ);

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

    // Определение класса для целевых объектов    общественный учебный класс EmployeeInfo {        частный int employeeId;        частный Нить имя;        частный Нить отделение;        // Получатели и сеттеры для всех свойств        // или публичный конструктор, использующий поля        общественный получать...        общественный набор...    }    // Получить список сотрудников, используя созданный выше объект cmd    DBReader читатель = новый DBReader();    пытаться {        читатель.открыто(cmd, getConnection());        Список<EmployeeInfo> empList = читатель.getBeanList(EmployeeInfo.учебный класс);    } наконец-то {        читатель.Закрыть()    }

Empire-db также поддерживает доступ к полям через ссылки на объекты или получение результатов запроса в виде XML.

История

Первоначально Empire-db была разработана в ESTEAM Software, немецкой компании по разработке программного обеспечения, которая использовала Empire-db для разработки различных приложений для различных отраслей.

В январе 2008 года Empire-db был официально открыт и впервые опубликован на SourceForge.net.

В июне 2008 года в Apache Software Foundation было подано предложение о преобразовании Empire-db в проект Apache Incubator. В июле 2008 года Empire-db была принята на инкубацию, и все права на Программное обеспечение были переданы Apache Foundation.

В октябре 2008 года Empire-db 2.0.4 был первым официальным выпуском инкубатора Apache, в котором все имена пакетов были изменены, чтобы они начинались с org.apache.empire.

Смотрите также

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