HHH-10022 - Continue documentation TLC (part 2)
This commit is contained in:
parent
85dbceac20
commit
800df6f44c
|
@ -6,7 +6,8 @@
|
|||
~ License: GNU Lesser General Public License (LGPL), version 2.1 or later.
|
||||
~ See the lgpl.txt file in the root directory or <http://www.gnu.org/licenses/lgpl-2.1.html>.
|
||||
-->
|
||||
<chapter xmlns="http://docbook.org/ns/docbook"
|
||||
<chapter xml:id="criteria"
|
||||
xmlns="http://docbook.org/ns/docbook"
|
||||
xmlns:xi="http://www.w3.org/2001/XInclude">
|
||||
|
||||
<title>Criteria</title>
|
||||
|
|
|
@ -56,9 +56,7 @@
|
|||
<xi:include href="chapters/batch/Batching.xml" />
|
||||
<xi:include href="chapters/caching/Caching.xml" />
|
||||
<xi:include href="chapters/events/Events.xml" />
|
||||
<!--
|
||||
<xi:include href="chapters/query_ql/HQL_JPQL.xml" />
|
||||
-->
|
||||
<xi:include href="chapters/query-hql/HQL.xml" />
|
||||
<xi:include href="chapters/query-criteria/Criteria.xml" />
|
||||
<xi:include href="chapters/query-native/Native.xml" />
|
||||
|
||||
|
|
|
@ -18,7 +18,7 @@
|
|||
<interfacename>javax.persistence.criteria.CriteriaQuery</interfacename> API. Eventually,
|
||||
Hibernate-specific criteria features will be ported as extensions to the JPA
|
||||
<interfacename>javax.persistence.criteria.CriteriaQuery</interfacename>. For details on the JPA APIs, see
|
||||
<xref linkend="query-criteria"/>.
|
||||
<xref linkend="criteria"/>.
|
||||
</para>
|
||||
<para>
|
||||
This information is copied as-is from the older Hibernate documentation.
|
||||
|
|
|
@ -6,7 +6,8 @@
|
|||
~ License: GNU Lesser General Public License (LGPL), version 2.1 or later.
|
||||
~ See the lgpl.txt file in the root directory or <http://www.gnu.org/licenses/lgpl-2.1.html>.
|
||||
-->
|
||||
<chapter xmlns="http://docbook.org/ns/docbook"
|
||||
<chapter xml:id="criteria"
|
||||
xmlns="http://docbook.org/ns/docbook"
|
||||
xmlns:xi="http://www.w3.org/2001/XInclude">
|
||||
|
||||
<title>Criteria</title>
|
||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -0,0 +1,10 @@
|
|||
select count(*), sum( o.total ), avg( o.total ), min( o.total ), max( o.total )
|
||||
from Order o
|
||||
|
||||
select count( distinct c.name )
|
||||
from Customer c
|
||||
|
||||
select c.id, c.name, sum( o.total )
|
||||
from Customer c
|
||||
left join c.orders o
|
||||
group by c.id, c.name
|
|
@ -0,0 +1,9 @@
|
|||
select year( current_date() ) - year( c.dateOfBirth )
|
||||
from Customer c
|
||||
|
||||
select c
|
||||
from Customer c
|
||||
where year( current_date() ) - year( c.dateOfBirth ) < 30
|
||||
|
||||
select o.customer, o.total + ( o.total * :salesTax )
|
||||
from Order o
|
|
@ -0,0 +1,36 @@
|
|||
select cal
|
||||
from Calendar cal
|
||||
where maxelement(cal.holidays) > current_date()
|
||||
|
||||
select o
|
||||
from Order o
|
||||
where maxindex(o.items) > 100
|
||||
|
||||
select o
|
||||
from Order o
|
||||
where minelement(o.items) > 10000
|
||||
|
||||
select m
|
||||
from Cat as m, Cat as kit
|
||||
where kit in elements(m.kittens)
|
||||
|
||||
// the above query can be re-written in jpql standard way:
|
||||
select m
|
||||
from Cat as m, Cat as kit
|
||||
where kit member of m.kittens
|
||||
|
||||
select p
|
||||
from NameList l, Person p
|
||||
where p.name = some elements(l.names)
|
||||
|
||||
select cat
|
||||
from Cat cat
|
||||
where exists elements(cat.kittens)
|
||||
|
||||
select p
|
||||
from Player p
|
||||
where 3 > all elements(p.scores)
|
||||
|
||||
select show
|
||||
from Show show
|
||||
where 'fizard' in indices(show.acts)
|
|
@ -0,0 +1,16 @@
|
|||
select c
|
||||
from Customer c
|
||||
join c.orders o
|
||||
join o.lineItems l
|
||||
join l.product p
|
||||
where o.status = 'pending'
|
||||
and p.status = 'backorder'
|
||||
|
||||
// alternate syntax
|
||||
select c
|
||||
from Customer c,
|
||||
in(c.orders) o,
|
||||
in(o.lineItems) l
|
||||
join l.product p
|
||||
where o.status = 'pending'
|
||||
and p.status = 'backorder'
|
|
@ -0,0 +1,3 @@
|
|||
select 'Mr. ' || c.name.first || ' ' || c.name.last
|
||||
from Customer c
|
||||
where c.gender = Gender.MALE
|
|
@ -0,0 +1,4 @@
|
|||
select new Family( mother, mate, offspr )
|
||||
from DomesticCat as mother
|
||||
join mother.mate as mate
|
||||
left join mother.kittens as offspr
|
|
@ -0,0 +1,7 @@
|
|||
select o
|
||||
from Order o
|
||||
where o.lineItems is empty
|
||||
|
||||
select c
|
||||
from Customer c
|
||||
where c.pastDueBills is not empty
|
|
@ -0,0 +1,8 @@
|
|||
select p
|
||||
from Payment p
|
||||
where type(p) = CreditCardPayment
|
||||
|
||||
select p
|
||||
from Payment p
|
||||
where type(p) = :aType
|
||||
|
|
@ -0,0 +1,10 @@
|
|||
// retrieve the total for all orders
|
||||
select sum( o.total )
|
||||
from Order o
|
||||
|
||||
// retrieve the total of all orders
|
||||
// *grouped by* customer
|
||||
select c.id, sum( o.total )
|
||||
from Order o
|
||||
inner join o.customer c
|
||||
group by c.id
|
|
@ -0,0 +1,5 @@
|
|||
select c.id, sum( o.total )
|
||||
from Order o
|
||||
inner join o.customer c
|
||||
group by c.id
|
||||
having sum( o.total ) > 10000.00
|
|
@ -0,0 +1,22 @@
|
|||
select o
|
||||
from Order o
|
||||
where o.items[0].id = 1234
|
||||
|
||||
select p
|
||||
from Person p, Calendar c
|
||||
where c.holidays['national day'] = p.birthDay
|
||||
and p.nationality.calendar = c
|
||||
|
||||
select i
|
||||
from Item i, Order o
|
||||
where o.items[ o.deliveredItemIndices[0] ] = i
|
||||
and o.id = 11
|
||||
|
||||
select i
|
||||
from Item i, Order o
|
||||
where o.items[ maxindex(o.items) ] = i
|
||||
and o.id = 11
|
||||
|
||||
select i
|
||||
from Item i, Order o
|
||||
where o.items[ size(o.items) - 1 ] = i
|
|
@ -0,0 +1,10 @@
|
|||
select c
|
||||
from Customer c
|
||||
join c.chiefExecutive ceo
|
||||
where ceo.age < 25
|
||||
|
||||
// same query but specifying join type as 'inner' explicitly
|
||||
select c
|
||||
from Customer c
|
||||
inner join c.chiefExecutive ceo
|
||||
where ceo.age < 25
|
|
@ -0,0 +1,15 @@
|
|||
// get customers who have orders worth more than $5000
|
||||
// or who are in "preferred" status
|
||||
select distinct c
|
||||
from Customer c
|
||||
left join c.orders o
|
||||
where o.value > 5000.00
|
||||
or c.status = 'preferred'
|
||||
|
||||
// functionally the same query but using the
|
||||
// 'left outer' phrase
|
||||
select distinct c
|
||||
from Customer c
|
||||
left outer join c.orders o
|
||||
where o.value > 5000.00
|
||||
or c.status = 'preferred'
|
|
@ -0,0 +1,3 @@
|
|||
select c
|
||||
from Customer c
|
||||
left join fetch c.orders o
|
|
@ -0,0 +1,9 @@
|
|||
select c
|
||||
from Customer c
|
||||
where c.chiefExecutive.age < 25
|
||||
|
||||
// same as
|
||||
select c
|
||||
from Customer c
|
||||
inner join c.chiefExecutive ceo
|
||||
where ceo.age < 25
|
|
@ -0,0 +1,19 @@
|
|||
select c
|
||||
from Customer c
|
||||
where c.chiefExecutive.age < 25
|
||||
and c.chiefExecutive.address.state = 'TX'
|
||||
|
||||
// same as
|
||||
select c
|
||||
from Customer c
|
||||
inner join c.chiefExecutive ceo
|
||||
where ceo.age < 25
|
||||
and ceo.address.state = 'TX'
|
||||
|
||||
// same as
|
||||
select c
|
||||
from Customer c
|
||||
inner join c.chiefExecutive ceo
|
||||
inner join ceo.address a
|
||||
where ceo.age < 25
|
||||
and a.state = 'TX'
|
|
@ -0,0 +1,4 @@
|
|||
select distinct c
|
||||
from Customer c
|
||||
left join c.orders o
|
||||
with o.value > 5000.00
|
|
@ -0,0 +1,16 @@
|
|||
String queryString =
|
||||
"select c " +
|
||||
"from Customer c " +
|
||||
"where c.name = ?1 " +
|
||||
" or c.nickName = ?1";
|
||||
|
||||
// HQL - as you can see, handled just like named parameters
|
||||
// in terms of API
|
||||
List customers = session.createQuery( queryString )
|
||||
.setParameter( "1", theNameOfInterest )
|
||||
.list();
|
||||
|
||||
// JPQL
|
||||
List<Customer> customers = entityManager.createQuery( queryString, Customer.class )
|
||||
.setParameter( 1, theNameOfInterest )
|
||||
.getResultList();
|
|
@ -0,0 +1,4 @@
|
|||
select new list(mother, offspr, mate.name)
|
||||
from DomesticCat as mother
|
||||
inner join mother.mate as mate
|
||||
left outer join mother.kittens as offspr
|
|
@ -0,0 +1 @@
|
|||
locate( string_expression, string_expression[, numeric_expression] )
|
|
@ -0,0 +1,7 @@
|
|||
select new map( mother as mother, offspr as offspr, mate as mate )
|
||||
from DomesticCat as mother
|
||||
inner join mother.mate as mate
|
||||
left outer join mother.kittens as offspr
|
||||
|
||||
select new map( max(c.bodyWeight) as max, min(c.bodyWeight) as min, count(*) as n )
|
||||
from Cat c
|
|
@ -0,0 +1,8 @@
|
|||
select p
|
||||
from Person p
|
||||
where 'John' member of p.nickNames
|
||||
|
||||
select p
|
||||
from Person p
|
||||
where p.name.first = 'Joseph'
|
||||
and 'Joey' not member of p.nickNames
|
|
@ -0,0 +1,5 @@
|
|||
// build a product between customers and active mailing campaigns so we can spam!
|
||||
select distinct cust, camp
|
||||
from Customer cust, Campaign camp
|
||||
where camp.type = 'mail'
|
||||
and current_timestamp() between camp.activeRange.start and camp.activeRange.end
|
|
@ -0,0 +1,5 @@
|
|||
// retrieve all customers with headquarters in the same state as Acme's headquarters
|
||||
select distinct c1
|
||||
from Customer c1, Customer c2
|
||||
where c1.address.state = c2.address.state
|
||||
and c2.name = 'Acme'
|
|
@ -0,0 +1,15 @@
|
|||
String queryString =
|
||||
"select c " +
|
||||
"from Customer c " +
|
||||
"where c.name = :name " +
|
||||
" or c.nickName = :name";
|
||||
|
||||
// HQL
|
||||
List customers = session.createQuery( queryString )
|
||||
.setParameter( "name", theNameOfInterest )
|
||||
.list();
|
||||
|
||||
// JPQL
|
||||
List<Customer> customers = entityManager.createQuery( queryString, Customer.class )
|
||||
.setParameter( "name", theNameOfInterest )
|
||||
.getResultList();
|
|
@ -0,0 +1,8 @@
|
|||
// return customers who have changed their last name
|
||||
select nullif( c.previousName.last, c.name.last )
|
||||
from Customer c
|
||||
|
||||
// equivalent CASE expression
|
||||
select case when c.previousName.last = c.name.last then null
|
||||
else c.previousName.last end
|
||||
from Customer c
|
|
@ -0,0 +1,29 @@
|
|||
// simple integer literal
|
||||
select o
|
||||
from Order o
|
||||
where o.referenceNumber = 123
|
||||
|
||||
// simple integer literal, typed as a long
|
||||
select o
|
||||
from Order o
|
||||
where o.referenceNumber = 123L
|
||||
|
||||
// decimal notation
|
||||
select o
|
||||
from Order o
|
||||
where o.total > 5000.00
|
||||
|
||||
// decimal notation, typed as a float
|
||||
select o
|
||||
from Order o
|
||||
where o.total > 5000.00F
|
||||
|
||||
// scientific notation
|
||||
select o
|
||||
from Order o
|
||||
where o.total > 5e+3
|
||||
|
||||
// scientific notation, typed as a float
|
||||
select o
|
||||
from Order o
|
||||
where o.total > 5e+3F
|
|
@ -0,0 +1,10 @@
|
|||
// legal because p.name is implicitly part of p
|
||||
select p
|
||||
from Person p
|
||||
order by p.name
|
||||
|
||||
select c.id, sum( o.total ) as t
|
||||
from Order o
|
||||
inner join o.customer c
|
||||
group by c.id
|
||||
order by t
|
|
@ -0,0 +1,19 @@
|
|||
select p
|
||||
from Customer c
|
||||
join c.paymentHistory p
|
||||
where c.id = 123
|
||||
and index(p) between 0 and 9
|
||||
|
||||
select c
|
||||
from Customer c
|
||||
where c.president.dateOfBirth
|
||||
between {d '1945-01-01'}
|
||||
and {d '1965-01-01'}
|
||||
|
||||
select o
|
||||
from Order o
|
||||
where o.total between 500 and 5000
|
||||
|
||||
select p
|
||||
from Person p
|
||||
where p.name between 'A' and 'E'
|
|
@ -0,0 +1,34 @@
|
|||
// numeric comparison
|
||||
select c
|
||||
from Customer c
|
||||
where c.chiefExecutive.age < 30
|
||||
|
||||
// string comparison
|
||||
select c
|
||||
from Customer c
|
||||
where c.name = 'Acme'
|
||||
|
||||
// datetime comparison
|
||||
select c
|
||||
from Customer c
|
||||
where c.inceptionDate < {d '2000-01-01'}
|
||||
|
||||
// enum comparison
|
||||
select c
|
||||
from Customer c
|
||||
where c.chiefExecutive.gender = com.acme.Gender.MALE
|
||||
|
||||
// boolean comparison
|
||||
select c
|
||||
from Customer c
|
||||
where c.sendEmail = true
|
||||
|
||||
// entity type comparison
|
||||
select p
|
||||
from Payment p
|
||||
where type(p) = WireTransferPayment
|
||||
|
||||
// entity value comparison
|
||||
select c
|
||||
from Customer c
|
||||
where c.chiefExecutive = c.chiefTechnologist
|
|
@ -0,0 +1,9 @@
|
|||
// select all players that scored at least 3 points
|
||||
// in every game.
|
||||
select p
|
||||
from Player p
|
||||
where 3 > all (
|
||||
select spg.points
|
||||
from StatsPerGame spg
|
||||
where spg.player = p
|
||||
)
|
|
@ -0,0 +1,8 @@
|
|||
in_expression ::= single_valued_expression
|
||||
[NOT] IN single_valued_list
|
||||
|
||||
single_valued_list ::= constructor_expression |
|
||||
(subquery) |
|
||||
collection_valued_input_parameter
|
||||
|
||||
constructor_expression ::= (expression[, expression]*)
|
|
@ -0,0 +1,36 @@
|
|||
select p
|
||||
from Payment p
|
||||
where type(p) in (CreditCardPayment, WireTransferPayment)
|
||||
|
||||
select c
|
||||
from Customer c
|
||||
where c.hqAddress.state in ('TX', 'OK', 'LA', 'NM')
|
||||
|
||||
select c
|
||||
from Customer c
|
||||
where c.hqAddress.state in ?
|
||||
|
||||
select c
|
||||
from Customer c
|
||||
where c.hqAddress.state in (
|
||||
select dm.state
|
||||
from DeliveryMetadata dm
|
||||
where dm.salesTax is not null
|
||||
)
|
||||
|
||||
// Not JPQL compliant!
|
||||
select c
|
||||
from Customer c
|
||||
where c.name in (
|
||||
('John','Doe'),
|
||||
('Jane','Doe')
|
||||
)
|
||||
|
||||
// Not JPQL compliant!
|
||||
select c
|
||||
from Customer c
|
||||
where c.chiefExecutive in (
|
||||
select p
|
||||
from Person p
|
||||
where ...
|
||||
)
|
|
@ -0,0 +1,4 @@
|
|||
like_expression ::=
|
||||
string_expression
|
||||
[NOT] LIKE pattern_value
|
||||
[ESCAPE escape_character]
|
|
@ -0,0 +1,13 @@
|
|||
select p
|
||||
from Person p
|
||||
where p.name like '%Schmidt'
|
||||
|
||||
select p
|
||||
from Person p
|
||||
where p.name not like 'Jingleheimmer%'
|
||||
|
||||
// find any with name starting with "sp_"
|
||||
select sp
|
||||
from StoredProcedureMetadata sp
|
||||
where sp.name like 'sp|_%' escape '|'
|
||||
|
|
@ -0,0 +1,9 @@
|
|||
// select everyone with an associated address
|
||||
select p
|
||||
from Person p
|
||||
where p.address is not null
|
||||
|
||||
// select everyone without an associated address
|
||||
select p
|
||||
from Person p
|
||||
where p.address is null
|
|
@ -0,0 +1,33 @@
|
|||
// Product.images is a Map<String,String> : key = a name, value = file path
|
||||
|
||||
// select all the image file paths (the map value) for Product#123
|
||||
select i
|
||||
from Product p
|
||||
join p.images i
|
||||
where p.id = 123
|
||||
|
||||
// same as above
|
||||
select value(i)
|
||||
from Product p
|
||||
join p.images i
|
||||
where p.id = 123
|
||||
|
||||
// select all the image names (the map key) for Product#123
|
||||
select key(i)
|
||||
from Product p
|
||||
join p.images i
|
||||
where p.id = 123
|
||||
|
||||
// select all the image names and file paths (the 'Map.Entry') for Product#123
|
||||
select entry(i)
|
||||
from Product p
|
||||
join p.images i
|
||||
where p.id = 123
|
||||
|
||||
// total the value of the initial line items for all orders for a customer
|
||||
select sum( li.amount )
|
||||
from Customer c
|
||||
join c.orders o
|
||||
join o.lineItems li
|
||||
where c.id = 123
|
||||
and index(li) = 1
|
|
@ -0,0 +1 @@
|
|||
root_entity_reference ::= entity_name [AS] identification_variable
|
|
@ -0,0 +1 @@
|
|||
CASE [ WHEN {test_conditional} THEN {match_result} ]* ELSE {miss_result} END
|
|
@ -0,0 +1,9 @@
|
|||
select case when c.name.first is not null then c.name.first
|
||||
when c.nickName is not null then c.nickName
|
||||
else '<no first name>' end
|
||||
from Customer c
|
||||
|
||||
// Again, the abbreviated form coalesce can handle this a
|
||||
// little more succinctly
|
||||
select coalesce( c.name.first, c.nickName, '<no first name>' )
|
||||
from Customer c
|
|
@ -0,0 +1 @@
|
|||
CASE {operand} WHEN {test_value} THEN {match_result} ELSE {miss_result} END
|
|
@ -0,0 +1,16 @@
|
|||
select case c.nickName when null then '<no nick name>' else c.nickName end
|
||||
from Customer c
|
||||
|
||||
// This NULL checking is such a common case that most dbs
|
||||
// define an abbreviated CASE form. For example:
|
||||
select nvl( c.nickName, '<no nick name>' )
|
||||
from Customer c
|
||||
|
||||
// or:
|
||||
select isnull( c.nickName, '<no nick name>' )
|
||||
from Customer c
|
||||
|
||||
// the standard coalesce abbreviated form can be used
|
||||
// to achieve the same result:
|
||||
select coalesce( c.nickName, '<no nick name>' )
|
||||
from Customer c
|
|
@ -0,0 +1 @@
|
|||
select c from com.acme.Cat c
|
|
@ -0,0 +1 @@
|
|||
select c from Cat c
|
|
@ -0,0 +1,3 @@
|
|||
delete_statement ::= delete_clause [where_clause]
|
||||
|
||||
delete_clause ::= DELETE FROM entity_name [[AS] identification_variable]
|
|
@ -0,0 +1,5 @@
|
|||
insert_statement ::= insert_clause select_statement
|
||||
|
||||
insert_clause ::= INSERT INTO entity_name (attribute_list)
|
||||
|
||||
attribute_list ::= state_field[, state_field ]*
|
|
@ -0,0 +1,2 @@
|
|||
String hqlInsert = "insert into DelinquentAccount (id, name) select c.id, c.name from Customer c where ...";
|
||||
int createdEntities = s.createQuery( hqlInsert ).executeUpdate();
|
|
@ -0,0 +1,7 @@
|
|||
select_statement :: =
|
||||
[select_clause]
|
||||
from_clause
|
||||
[where_clause]
|
||||
[groupby_clause]
|
||||
[having_clause]
|
||||
[orderby_clause]
|
|
@ -0,0 +1,11 @@
|
|||
update_statement ::= update_clause [where_clause]
|
||||
|
||||
update_clause ::= UPDATE entity_name [[AS] identification_variable]
|
||||
SET update_item {, update_item}*
|
||||
|
||||
update_item ::= [identification_variable.]{state_field | single_valued_object_field}
|
||||
= new_value
|
||||
|
||||
new_value ::= scalar_expression |
|
||||
simple_entity_expression |
|
||||
NULL
|
|
@ -0,0 +1,8 @@
|
|||
String hqlUpdate =
|
||||
"update Customer c " +
|
||||
"set c.name = :newName " +
|
||||
"where c.name = :oldName";
|
||||
int updatedEntities = session.createQuery( hqlUpdate )
|
||||
.setString( "newName", newName )
|
||||
.setString( "oldName", oldName )
|
||||
.executeUpdate();
|
|
@ -0,0 +1,8 @@
|
|||
String hqlVersionedUpdate =
|
||||
"update versioned Customer c " +
|
||||
"set c.name = :newName " +
|
||||
"where c.name = :oldName";
|
||||
int updatedEntities = s.createQuery( hqlUpdate )
|
||||
.setString( "newName", newName )
|
||||
.setString( "oldName", oldName )
|
||||
.executeUpdate();
|
|
@ -0,0 +1,8 @@
|
|||
String jpqlUpdate =
|
||||
"update Customer c " +
|
||||
"set c.name = :newName " +
|
||||
"where c.name = :oldName";
|
||||
int updatedEntities = entityManager.createQuery( jpqlUpdate )
|
||||
.setString( "newName", newName )
|
||||
.setString( "oldName", oldName )
|
||||
.executeUpdate();
|
|
@ -0,0 +1,8 @@
|
|||
select c
|
||||
from Customer c
|
||||
where c.name = 'Acme'
|
||||
|
||||
select c
|
||||
from Customer c
|
||||
where c.name = 'Acme''s Pretzel Logic'
|
||||
|
|
@ -0,0 +1 @@
|
|||
substring( string_expression, numeric_expression [, numeric_expression] )
|
|
@ -28,7 +28,7 @@ Covers reference topics targeting users.
|
|||
* Batching (needs lot of work - not started - open questions)
|
||||
* Caching (needs some work)
|
||||
* Events (need some work)
|
||||
* Query - HQL/JPQL (needs lots of work)
|
||||
* Query - HQL/JPQL (still need to document APIs)
|
||||
* <strike>Query - Criteria</strike>
|
||||
* <strike>Query - Native (copy from old)</strike>
|
||||
* Multi_Tenancy (needs some work)
|
||||
|
|
Loading…
Reference in New Issue