Copyright (c) 2008 - 2013 Oracle Corporation. All rights reserved.
This program and the accompanying materials are made available under the
terms of the Eclipse Public License v1.0 and Eclipse Distribution License v. 1.0
which accompanies this distribution.
The Eclipse Public License is available at http://www.eclipse.org/legal/epl-v10.html
and the Eclipse Distribution License is available at
http://www.eclipse.org/org/documents/edl-v10.php.
Contributors:
Linda DeMichiel - Java Persistence 2.1
Linda DeMichiel - Java Persistence 2.0
/*******************************************************************************
* Copyright (c) 2008 - 2013 Oracle Corporation. All rights reserved.
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v1.0 and Eclipse Distribution License v. 1.0
* which accompanies this distribution.
* The Eclipse Public License is available at http://www.eclipse.org/legal/epl-v10.html
* and the Eclipse Distribution License is available at
* http://www.eclipse.org/org/documents/edl-v10.php.
*
* Contributors:
* Linda DeMichiel - Java Persistence 2.1
* Linda DeMichiel - Java Persistence 2.0
*
******************************************************************************/
package javax.persistence.criteria;
import java.util.List;
import javax.persistence.metamodel.ListAttribute;
The ListJoin
interface is the type of the result of
joining to a collection over an association or element
collection that has been specified as a java.util.List
.
Type parameters: - <Z> – the source type of the join
- <E> – the element type of the target List
Since: Java Persistence 2.0
/**
* The <code>ListJoin</code> interface is the type of the result of
* joining to a collection over an association or element
* collection that has been specified as a <code>java.util.List</code>.
*
* @param <Z> the source type of the join
* @param <E> the element type of the target List
*
* @since Java Persistence 2.0
*/
public interface ListJoin<Z, E>
extends PluralJoin<Z, List<E>, E> {
Modify the join to restrict the result according to the
specified ON condition and return the join object.
Replaces the previous ON condition, if any.
@param restriction a simple or compound boolean expression
@return the modified join object
@since Java Persistence 2.1
/**
* Modify the join to restrict the result according to the
* specified ON condition and return the join object.
* Replaces the previous ON condition, if any.
* @param restriction a simple or compound boolean expression
* @return the modified join object
* @since Java Persistence 2.1
*/
ListJoin<Z, E> on(Expression<Boolean> restriction);
Modify the join to restrict the result according to the
specified ON condition and return the join object.
Replaces the previous ON condition, if any.
@param restrictions zero or more restriction predicates
@return the modified join object
@since Java Persistence 2.1
/**
* Modify the join to restrict the result according to the
* specified ON condition and return the join object.
* Replaces the previous ON condition, if any.
* @param restrictions zero or more restriction predicates
* @return the modified join object
* @since Java Persistence 2.1
*/
ListJoin<Z, E> on(Predicate... restrictions);
Return the metamodel representation for the list attribute.
Returns: metamodel type representing the List
that is
the target of the join
/**
* Return the metamodel representation for the list attribute.
* @return metamodel type representing the <code>List</code> that is
* the target of the join
*/
ListAttribute<? super Z, E> getModel();
Create an expression that corresponds to the index of
the object in the referenced association or element
collection.
This method must only be invoked upon an object that
represents an association or element collection for
which an order column has been defined.
Returns: expression denoting the index
/**
* Create an expression that corresponds to the index of
* the object in the referenced association or element
* collection.
* This method must only be invoked upon an object that
* represents an association or element collection for
* which an order column has been defined.
* @return expression denoting the index
*/
Expression<Integer> index();
}