Class InExpressionStateObject

  • All Implemented Interfaces:
    ListHolderStateObject<StateObject>, StateObject

    public class InExpressionStateObject
    extends AbstractListHolderStateObject<StateObject>
    The state field path expression must have a string, numeric, or enum value. The literal and/or input parameter values must be like the same abstract schema type of the state field path expression in type.

    The results of the subquery must be like the same abstract schema type of the state field path expression in type.

    There must be at least one element in the comma separated list that defines the set of values for the IN expression. If the value of a state field path expression in an IN or NOT IN expression is NULL or unknown, the value of the expression is unknown.

    JPA 1.0:

    BNF: in_expression ::= state_field_path_expression [NOT] IN(in_item {, in_item}* | subquery)

    JPA 2.0
    BNF: in_expression ::= {state_field_path_expression | type_discriminator} [NOT] IN { ( in_item {, in_item}* ) | (subquery) | collection_valued_input_parameter }

    Version:
    2.4
    See Also:
    InExpression
    Author:
    Pascal Filion
    Since:
    2.4
    • Field Detail

      • ITEMS_LIST

        public static final java.lang.String ITEMS_LIST
        Notifies the list of items has changed.
        See Also:
        Constant Field Values
      • NOT_PROPERTY

        public static final java.lang.String NOT_PROPERTY
        Notifies the visibility of the NOT identifier has changed.
        See Also:
        Constant Field Values
      • STATE_OBJECT_PROPERTY

        public static final java.lang.String STATE_OBJECT_PROPERTY
        Notifies the StateObject representing the state field path expression or the input parameter has changed.
        See Also:
        Constant Field Values
    • Constructor Detail

      • InExpressionStateObject

        public InExpressionStateObject​(StateObject parent)
        Creates a new InExpressionStateObject.
        Parameters:
        parent - The parent of this state object, which cannot be null
        Throws:
        java.lang.NullPointerException - The given parent cannot be null
      • InExpressionStateObject

        public InExpressionStateObject​(StateObject parent,
                                       boolean not,
                                       java.lang.String path,
                                       java.util.List<java.lang.String> items)
        Creates a new InExpressionStateObject.
        Parameters:
        parent - The parent of this state object, which cannot be null
        path -
        not - Determines whether the NOT identifier is part of the expression or not
        items - The list of JPQL fragments that will be parsed and converted into StateObject
        Throws:
        java.lang.NullPointerException - The given parent cannot be null
      • InExpressionStateObject

        public InExpressionStateObject​(StateObject parent,
                                       boolean not,
                                       java.lang.String path,
                                       java.lang.String parameter)
        Creates a new InExpressionStateObject.
        Parameters:
        parent - The parent of this state object, which cannot be null
        path -
        not - Determines whether the NOT identifier is part of the expression or not
        parameter - The
        Throws:
        java.lang.NullPointerException - The given parent cannot be null
      • InExpressionStateObject

        public InExpressionStateObject​(StateObject parent,
                                       StateObject stateObject,
                                       boolean not,
                                       java.util.List<? extends StateObject> items)
        Creates a new InExpressionStateObject.
        Parameters:
        parent - The parent of this state object, which cannot be null
        stateObject -
        not - Determines whether the NOT identifier is part of the expression or not
        items -
        Throws:
        java.lang.NullPointerException - The given parent cannot be null
      • InExpressionStateObject

        public InExpressionStateObject​(StateObject parent,
                                       StateObject stateFieldPath,
                                       java.util.List<? extends StateObject> items)
        Creates a new InExpressionStateObject.
        Parameters:
        parent - The parent of this state object, which cannot be null
        stateFieldPath -
        items -
        Throws:
        java.lang.NullPointerException - The given parent cannot be null
      • InExpressionStateObject

        public InExpressionStateObject​(StateObject parent,
                                       java.lang.String path,
                                       java.util.List<java.lang.String> items)
        Creates a new InExpressionStateObject.
        Parameters:
        parent - The parent of this state object, which cannot be null
        path -
        items - The list of JPQL fragments that will be parsed and converted into StateObject
        Throws:
        java.lang.NullPointerException - The given parent cannot be null
    • Method Detail

      • addNot

        public InExpressionStateObject addNot()
        Makes sure the NOT identifier is specified.
        Returns:
        This object
      • getExpression

        public InExpression getExpression()
        Returns the actual parsed object if this StateObject representation of the JPQL query was created by parsing an existing JPQL query.
        Specified by:
        getExpression in interface StateObject
        Overrides:
        getExpression in class AbstractStateObject
        Returns:
        The parsed object when a JPQL query is parsed and converted into a StateObject or null when the JPQL query is manually created (i.e. not from a string)
      • getStateObject

        public StateObject getStateObject()
        Returns
        Returns:
      • hasNot

        public boolean hasNot()
        Determines whether the NOT identifier is used or not.
        Returns:
        true if the NOT identifier is part of the expression; false otherwise
      • hasStateObject

        public boolean hasStateObject()
        Determines whether
        Returns:
      • isSingleInputParameter

        public boolean isSingleInputParameter()
        Determines whether what was parsed after the IN identifier is a single input parameter.
        Returns:
        true if the only item is an input parameter; false otherwise
      • parse

        public void parse​(java.lang.String jpqlFragment)
        Parses the given JPQL fragment, which represents either a single or many items, the fragment will be parsed and converted into StateObject.
        Parameters:
        jpqlFragment - The portion of the query to parse
      • removeNot

        public void removeNot()
        Makes sure the NOT identifier is not specified.
      • setExpression

        public void setExpression​(InExpression expression)
        Keeps a reference of the parsed object object, which should only be done when this object is instantiated during the conversion of a parsed JPQL query into StateObjects.
        Parameters:
        expression - The parsed object representing an IN expression
      • setNot

        public void setNot​(boolean not)
        Sets whether the NOT identifier should be part of the expression or not.
        Parameters:
        not - true if the NOT identifier should be part of the expression; false otherwise
      • setSingleInputParameter

        public void setSingleInputParameter​(boolean singleInputParameter)
        Sets whether what was parsed after the IN identifier is a single input parameter.
        Parameters:
        singleInputParameter - true if the only item is an input parameter; false otherwise
      • setStateObject

        public void setStateObject​(StateObject stateObject)
        Sets
        Parameters:
        stateObject -
      • toggleNot

        public void toggleNot()
        Changes the visibility state of the NOT identifier.
      • toTextInternal

        protected void toTextInternal​(java.lang.Appendable writer)
                               throws java.io.IOException
        Prints out a string representation of this StateObject, which should not be used to define a true string representation of a JPQL query but should be used for debugging purposes.
        Specified by:
        toTextInternal in class AbstractStateObject
        Parameters:
        writer - The writer used to print out the string representation
        Throws:
        java.io.IOException - This should never happens, it is only required because Appendable is used instead of any concrete class