Hibernate ORM

Processor

Hibernate Processor is a standard Java annotation processor which produces the Jakarta Persistence static metamodel, validates queries at compilation time, and implements Jakarta Data repositories.

Jakarta Persistence static metamodel

The static metamodel is a standard part of JPA. It lets us reference the persistent fields and properties of an entity in a completely typesafe way. Consider the entity class Order:

@Entity
public class Order {
    @Id
    @GeneratedValue
    Integer id;
    @ManyToOne
    Customer customer;
    @OneToMany
    Set<Item> items;
    BigDecimal totalCost;

    // ...
}

Hibernate Processor would generate the static metamodel class Order_, something like this:

// code generated by the annotation processor
@StaticMetamodel(Order.class)
public class Order_ {
    public static volatile SingularAttribute<Order, Integer> id;
    public static volatile SingularAttribute<Order, Customer> customer;
    public static volatile SetAttribute<Order, Item> items;
    public static volatile SingularAttribute<Order, BigDecimal> totalCost;
}

The static metamodel class allows to write criteria queries like this, without the use of strings:

var builder = entityManager.getCriteriaBuilder();
var query = builder.createQuery(Order.class);
var item = query.from(Order.class).join(Order_.items);
query.where(builder.equal(item.get(Item_.id), 5)).distinct(true);

Query validation

Hibernate Processor is able to completely validate HQL, JPQL, and JDQL queries provided via annotations—​for example, using a JPA @NamedQuery annotation, a Jakarta Data @Query annotation, or a Hibernate @HQL annotation—​and report any errors in the syntax or typing of the query at compilation time.

Hibernate Data Repositories

Hibernate Processor is the thing which provides the implementation of a @Repository interface in our implementation of Jakarta Data, Hibernate Data Repositories.

You write a repository interface like this:

@Transactional
@Repository
public interface Library {

    @Find
    Optional<Book> byIsbn(String isbn);

    @Find
    List<Book> byTitle(@Pattern String title);

    @Insert
    void add(Book book);

    @Delete
    void delete(String isbn);

    @Find
    List<Book> allBooks(Sort<Book> bookSort);

    @Find
    @OrderBy(_Book.ISBN)
    List<Book> allBooks();

}

Then Hibernate Processor provides an implementation which complies with the semantics defined by the Jakarta Data specification.

Back to top