Ebean - Ebean

Ebean
Разработчики)Avaje
Стабильный выпуск
10.3.2 / 25 июня 2017 г. (2017-06-25)
Репозиторий Отредактируйте это в Викиданных
Написано вЯва
Операционная системаКроссплатформенность
ПлатформаЯва
Размер1,9 МБ (в архиве)
ТипОбъектно-реляционное отображение
ЛицензияЛицензия Apache
Интернет сайтebean-orm.github.io

Ebean является объектно-реляционное отображение продукт написан в Ява. Он разработан таким образом, чтобы его было проще использовать и понять, чем JPA (Java Persistence API) или JDO (объекты данных Java).

Простой API

У Ebean более простой API, чем у JPA. Это достигается за счет 'Сессия меньше ' архитектура. Ebean не требуется JPA EntityManager или JDO PersistenceManager, и это устраняет концепции отсоединенных / прикрепленных bean-компонентов и проблемы, связанные с очисткой / очисткой и «управлением сеансом» EntityManager. Все это значительно упрощает изучение, понимание и использование Ebean API.

Реляционные особенности

Хотя Ebean имеет полные функции ORM (эквивалент JPA), он также включает в себя функции SQL / Relational. Идея состоит в том, что многие усилия по разработке требуют контроля над конкретным sql, вызовом хранимых процедур или проще решаются с помощью «реляционных» подходов. Конечная цель Ebean - объединить лучшие функции ORM из JPA с лучшими «реляционными» функциями таких продуктов, как MyBatis, в единую структуру персистентности.

Объектно-реляционное отображение

Ebean использует то же сопоставление, что и JPA, с аннотациями @Entity, @Table, @OneToMany и т. Д. И xml. Сопоставление компонентов Entity должно быть совместимо между Ebean и JPA.

Выходя за рамки JPA Ebean поддерживает Java Generics и получение «частичных» объектов с помощью своего объекта Query.

Примеры

// находим покупателя по idПокупатель покупатель = Ebean.найти(Покупатель.класс, 1);// Сохраняем изменения объекта клиентапокупатель.спасти();// более сложный запрос с объединениямиСписок<порядок> порядок =   Ebean.найти(порядок.класс)    .принести("покупатель")    .принести("customer.billingAddress")    .принести("customer.shippingAddress")    .принести("подробности")    .принести("детали.продукт", "имя")    .где().экв("shipDate", сегодня)    .findList();

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

внешние ссылки