Module jakarta.data

Interface BasicRepository<T,K>

Type Parameters:
T - the type of the primary entity class of the repository.
K - the type of the unique identifier attribute of the primary entity.
All Superinterfaces:
DataRepository<T,K>
All Known Subinterfaces:
CrudRepository<T,K>

public interface BasicRepository<T,K> extends DataRepository<T,K>

A built-in repository supertype for performing basic operations on entities.

The type parameters of BasicRepository<T,K> capture the primary entity type (T) for the repository and the type of the unique identifier attribute (K) of the primary entity type.

The primary entity type is used for repository methods, such as countBy... and deleteBy..., which do not explicitly specify an entity type.

Example entity:

 @Entity
 public class Employee {
     @Id
     public int badgeNumber;
     public String firstName;
     public String lastName;
     ...
 }
 

Example repository:

 @Repository
 public interface Employees extends BasicRepository<Employee, Integer> {

     boolean deleteByBadgeNumber(int badgeNum);

     ...
 }
 

Example usage:

 @Inject
 Employees employees;

 ...

 Employee emp = ...
 emp = employees.save(emp);

 boolean deleted = employees.deleteByBadgeNumber(emp.badgeNum);

 PageRequest<Employee> pageRequest = PageRequest.of(Employee.class).size(25).sortBy(Sort.asc("name"));
 Page<Employee> page = people.findAll(pageRequest);
 

The module Javadoc provides an overview of Jakarta Data.

  • Method Summary

    Modifier and Type
    Method
    Description
    void
    delete(T entity)
    Deletes a given entity.
    void
    deleteAll(List<? extends T> entities)
    Deletes the given entities.
    void
    Deletes the entity with the given Id.
    Retrieves all persistent entities of the specified type from the database.
    findAll(PageRequest<T> pageRequest)
    Returns a Page of entities according to the page request that is provided as the PageRequest parameter.
    findById(K id)
    Retrieves an entity by its Id.
    <S extends T>
    S
    save(S entity)
    Saves a given entity to the database.
    <S extends T>
    List<S>
    saveAll(List<S> entities)
    Saves all given entities to the database.
  • Method Details

    • save

      @Save <S extends T> S save(S entity)
      Saves a given entity to the database. If the entity has an Id or key that exists in the database, the method will update the existing record. Otherwise, it will insert a new record.

      If the entity has a non-null Id, the method will attempt to update the existing record in the database. If the entity does not exist in the database or has a null Id, then this method will insert a new record into the database.

      The entity instance that is returned as a result value of this method must be updated with all automatically generated values and incremented values that changed due to the save. After invoking this method, do not continue to use the entity value that is supplied as a parameter. This method makes no guarantees about the state of the entity value that is supplied as a parameter.

      If the entity uses optimistic locking and the version differs from the version in the database, an OptimisticLockingFailureException will be thrown.

      Type Parameters:
      S - Type of the entity to save.
      Parameters:
      entity - The entity to be saved. Must not be null.
      Returns:
      The saved entity; never null.
      Throws:
      OptimisticLockingFailureException - If the entity uses optimistic locking and the version in the database differs from the version in the entity.
      NullPointerException - If the provided entity is null.
    • saveAll

      @Save <S extends T> List<S> saveAll(List<S> entities)
      Saves all given entities to the database. If an entity has a non-null Id that exists in the database, the method will update the existing record. Otherwise, it will insert a new record.

      If an entity has a non-null Id, this method will attempt to update the existing record in the database. If an entity does not exist in the database or has a null Id, then this method inserts a new record into the database.

      The entity instances that are returned as a result of this method must be updated with all automatically generated values and incremented values that changed due to the save. After invoking this method, do not continue to use the entity values that are supplied in the parameter. This method makes no guarantees about the state of the entity values that are supplied in the parameter.

      Type Parameters:
      S - Type of entity to save.
      Parameters:
      entities - An iterable of entities.
      Returns:
      The saved entities; will never be null.
      Throws:
      OptimisticLockingFailureException - If an entity has a version for optimistic locking that differs from the version in the database.
      NullPointerException - If either the iterable is null or any element is null.
    • findById

      @Find Optional<T> findById(K id)
      Retrieves an entity by its Id.
      Parameters:
      id - must not be null.
      Returns:
      the entity with the given Id or Optional.empty() if none is found.
      Throws:
      NullPointerException - when the Id is null.
    • findAll

      @Find Stream<T> findAll()
      Retrieves all persistent entities of the specified type from the database.
      Returns:
      a stream of all entities; will never be null.
      Throws:
      UnsupportedOperationException - for Key-Value and Wide-Column databases that are not capable of the findAll operation.
    • findAll

      @Find Page<T> findAll(PageRequest<T> pageRequest)
      Returns a Page of entities according to the page request that is provided as the PageRequest parameter.
      Parameters:
      pageRequest - the request for a paginated result; must not be null.
      Returns:
      a page of entities; will never be null.
      Throws:
      NullPointerException - when pageRequest is null.
      UnsupportedOperationException - for Key-Value and Wide-Column databases when the PageRequest.Mode.CURSOR_NEXT or PageRequest.Mode.CURSOR_PREVIOUS pagination mode is selected.
      See Also:
    • deleteById

      @Delete void deleteById(K id)
      Deletes the entity with the given Id.

      If the entity is not found in the persistence store it is silently ignored.

      Parameters:
      id - must not be null.
      Throws:
      NullPointerException - when the Id is null.
    • delete

      @Delete void delete(T entity)
      Deletes a given entity. Deletion is performed by matching the Id, and if the entity is versioned (for example, with jakarta.persistence.Version), then also the version. Other properties of the entity do not need to match.
      Parameters:
      entity - must not be null.
      Throws:
      OptimisticLockingFailureException - if the entity is not found in the database for deletion or has a version for optimistic locking that is inconsistent with the version in the database.
      NullPointerException - when the entity is null
    • deleteAll

      @Delete void deleteAll(List<? extends T> entities)
      Deletes the given entities. Deletion of each entity is performed by matching the unique identifier, and if the entity is versioned (for example, with jakarta.persistence.Version), then also the version. Other properties of the entity do not need to match.
      Parameters:
      entities - Must not be null. Must not contain null elements.
      Throws:
      OptimisticLockingFailureException - If an entity is not found in the database for deletion or has a version for optimistic locking that is inconsistent with the version in the database.
      NullPointerException - If the iterable is null or contains null elements.