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.Set;
import javax.persistence.metamodel.SetAttribute;
The SetJoin
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.Set
.
Type parameters: - <Z> – the source type of the join
- <E> – the element type of the target
Set
Since: Java Persistence 2.0
/**
* The <code>SetJoin</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.Set</code>.
*
* @param <Z> the source type of the join
* @param <E> the element type of the target <code>Set</code>
*
* @since Java Persistence 2.0
*/
public interface SetJoin<Z, E> extends PluralJoin<Z, Set<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
*/
SetJoin<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
*/
SetJoin<Z, E> on(Predicate... restrictions);
Return the metamodel representation for the set attribute.
Returns: metamodel type representing the Set
that is
the target of the join
/**
* Return the metamodel representation for the set attribute.
* @return metamodel type representing the <code>Set</code> that is
* the target of the join
*/
SetAttribute<? super Z, E> getModel();
}