javadoc preamble for Query

This commit is contained in:
Gavin King 2022-01-22 10:48:50 +01:00
parent eb9e70e30d
commit 891435f3bb
3 changed files with 26 additions and 8 deletions

View File

@ -19,9 +19,9 @@ import jakarta.persistence.Parameter;
import jakarta.persistence.TemporalType; import jakarta.persistence.TemporalType;
/** /**
* Models a mutation (insert, update and delete) query. It is a slimmed * Models a mutation (insert, update, or delete) query. It is a slimmed
* down version of {@link Query}, but providing only methods relevant to * down version of {@link Query}, but providing only methods relevant to
* mutation queries * mutation queries.
* *
* @author Steve Ebersole * @author Steve Ebersole
*/ */

View File

@ -37,15 +37,33 @@ import jakarta.persistence.TemporalType;
import jakarta.persistence.TypedQuery; import jakarta.persistence.TypedQuery;
/** /**
* Represents an HQL or Criteria query. * Represents a {@link jakarta.persistence.criteria.CriteriaBuilder criteria query}
* * or a query written in HQL. The subtype {@link NativeQuery} represents a query
* Hibernate extension of {@link TypedQuery}, adapting to the * written in native SQL.
* {@link org.hibernate.query.CommonQueryContract} hierarchy * <p>
* This type simply mixes {@link TypedQuery} defined by JPA with {@link SelectionQuery}
* and {@link MutationQuery}. Unfortunately, JPA does not distinguish between
* {@link SelectionQuery selection queries} and {@link MutationQuery mutation queries},
* so we lose that distinction here. However, every {@code Query} may logically be
* classified as one or the other.
* <p>
* A {@code Query} controls how a query is executed, and allows arguments to be
* bound to its parameters.
* <ul>
* <li>Selection queries are usually executed using {@link #getResultList()} or
* {@link #getSingleResult()}, and mutation queries must be executed using
* {@link #executeUpdate()}.
* <li>The methods {@link #setMaxResults(int)} and {@link #setFirstResult(int)}
* control limits and pagination.
* <li>The various overloads of {@link #setParameter(String, Object)} and
* {@link #setParameter(int, Object)} allow arguments to be bound to named and
* ordinal parameters defined by the query.
* </ul>
* *
* @author Gavin King * @author Gavin King
* @author Steve Ebersole * @author Steve Ebersole
* *
* @param <R> The query result type, for typed queries, or {@code Object} for untyped queries * @param <R> The query result type, for typed queries, or {@link Object} for untyped queries
*/ */
@Incubating @Incubating
public interface Query<R> extends SelectionQuery, MutationQuery, TypedQuery<R> { public interface Query<R> extends SelectionQuery, MutationQuery, TypedQuery<R> {

View File

@ -34,7 +34,7 @@ import jakarta.persistence.TemporalType;
/** /**
* Models a selection query returning results. It is a slimmed down version * Models a selection query returning results. It is a slimmed down version
* of {@link Query}, but providing only methods relevant to selection queries * of {@link Query}, but providing only methods relevant to selection queries.
* *
* @author Steve Ebersole * @author Steve Ebersole
*/ */