HHH-18979 add Order/Restriction to jdoc for @Find and @HQL

This commit is contained in:
Gavin King 2024-12-28 13:55:33 +01:00
parent f27e5e8be1
commit aea72cccd5
2 changed files with 36 additions and 1 deletions

View File

@ -39,12 +39,25 @@ import static java.lang.annotation.RetentionPolicy.CLASS;
* Notice that: * Notice that:
* <ul> * <ul>
* <li>the types and names of the method parameters exactly match the * <li>the types and names of the method parameters exactly match the
* types and names of the corresponding fields of the entity. * types and names of the corresponding fields of the entity, and
* <li>there's no special naming convention for the {@code @Find} * <li>there's no special naming convention for the {@code @Find}
* methods&mdash;they may be named arbitrarily, and their names * methods&mdash;they may be named arbitrarily, and their names
* encode no semantics. * encode no semantics.
* </ul> * </ul>
* <p> * <p>
* Alternatively, a method parameter may have the type
* {@link org.hibernate.query.range.Range Range&lt;T&gt;} where
* {@code T} is the type of the corresponding field in the entity.
* <pre>
* &#064;Find
* Book getBookForIsbn(Range&lt;String&gt; isbn);
*
* &#064;Find
* List&lt;Book&gt; getBooksWithTitle(Range&lt;String&gt; title);
* </pre>
* This allows the matching field to be restricted based on a variety
* of criteria expressed via the static factory methods of {@code Range}.
* <p>
* It's even possible to query by a field of an embedded object: * It's even possible to query by a field of an embedded object:
* <pre> * <pre>
* &#064;Find * &#064;Find
@ -154,6 +167,17 @@ import static java.lang.annotation.RetentionPolicy.CLASS;
* <li>return type {@link org.hibernate.query.KeyedResultList}, and * <li>return type {@link org.hibernate.query.KeyedResultList}, and
* <li>a parameter of type {@link org.hibernate.query.KeyedPage}. * <li>a parameter of type {@link org.hibernate.query.KeyedPage}.
* </ul> * </ul>
* <p>
* Finally, a method might have a parameter of type
* {@link org.hibernate.query.Restriction Restriction<? super E>},
* allowing the caller to apply an arbitrary filtering criterion to
* the query results.
* <p>
* For example:
* <pre>
* &#064;Find
* List&lt;Book&gt; getBooks(Restriction&lt;Book&gt; filter, List&lt;Order&lt;Book&gt;&gt; order);
* </pre>
* *
* @see HQL * @see HQL
* @see SQL * @see SQL

View File

@ -134,6 +134,17 @@ import static java.lang.annotation.RetentionPolicy.CLASS;
* <li>a parameter of type {@link org.hibernate.query.KeyedPage}. * <li>a parameter of type {@link org.hibernate.query.KeyedPage}.
* </ul> * </ul>
* <p> * <p>
* Finally, a method might have a parameter of type
* {@link org.hibernate.query.Restriction Restriction<? super E>},
* allowing the caller to apply an arbitrary filtering criterion to
* the query results.
* <p>
* For example:
* <pre>
* &#064;HQL("from Book")
* List&lt;Book&gt; findBooks(Restriction&lt;Book&gt; filter, List&lt;Order&lt;Book&gt;&gt; order);
* </pre>
* <p>
* Queries specified using this annotation are always validated by * Queries specified using this annotation are always validated by
* the Metamodel Generator, and so it isn't necessary to specify the * the Metamodel Generator, and so it isn't necessary to specify the
* {@link CheckHQL} annotation. * {@link CheckHQL} annotation.