Skip to content

Commit

Permalink
add support for 'nulls first' and 'nulls last' in queries
Browse files Browse the repository at this point in the history
  • Loading branch information
gavinking committed Aug 9, 2023
1 parent 4daf494 commit df94048
Show file tree
Hide file tree
Showing 3 changed files with 69 additions and 10 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -117,19 +117,35 @@ public interface CriteriaBuilder {

/**
* Create an ordering by the ascending value of the expression.
* @param x expression used to define the ordering
* @param expression expression used to define the ordering
* @return ascending ordering corresponding to the expression
*/
Order asc(Expression<?> x);
Order asc(Expression<?> expression);

/**
* Create an ordering by the descending value of the expression.
* @param x expression used to define the ordering
* @param expression expression used to define the ordering
* @return descending ordering corresponding to the expression
*/
Order desc(Expression<?> x);
Order desc(Expression<?> expression);

/**
* Create an ordering by the ascending value of the expression.
* @param expression expression used to define the ordering
* @param nullPrecedence the precedence of null values
* @return ascending ordering corresponding to the expression
*/
Order asc(Expression<?> expression, NullPrecedence nullPrecedence);

/**
* Create an ordering by the descending value of the expression.
* @param expression expression used to define the ordering
* @param nullPrecedence the precedence of null values
* @return descending ordering corresponding to the expression
*/
Order desc(Expression<?> expression, NullPrecedence nullPrecedence);



//aggregate functions:

/**
Expand Down
39 changes: 39 additions & 0 deletions api/src/main/java/jakarta/persistence/criteria/NullPrecedence.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
/*
* Copyright (c) 2008, 2020 Oracle and/or its affiliates. All rights reserved.
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v. 2.0 which is available at
* http://www.eclipse.org/legal/epl-2.0,
* or the Eclipse Distribution License v. 1.0 which is available at
* http://www.eclipse.org/org/documents/edl-v10.php.
*
* SPDX-License-Identifier: EPL-2.0 OR BSD-3-Clause
*/

// Contributors:
// Gavin King - 3.2

package jakarta.persistence.criteria;

/**
* Specifies the precedence of null values within query result sets.
*
* @see CriteriaBuilder#asc(Expression, NullPrecedence)
* @see CriteriaBuilder#desc(Expression, NullPrecedence)
*
* @since 3.2
*/
public enum NullPrecedence {
/**
* Null precedence not specified.
*/
NONE,
/**
* Null values occur at the beginning of the result set.
*/
FIRST,
/**
* Null values occur at the end of the result set.
*/
LAST
}
14 changes: 9 additions & 5 deletions spec/src/main/asciidoc/ch04-query-language.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -320,10 +320,10 @@ future use.] are reserved identifiers: ABS, ALL, AND, ANY, AS, ASC,
AVG, BETWEEN, BIT_LENGTH, BOTH, BY, CASE, CEILING, CHAR_LENGTH,
CHARACTER_LENGTH, CLASS, COALESCE, CONCAT, COUNT, CURRENT_DATE,
CURRENT_TIME, CURRENT_TIMESTAMP, DELETE, DESC, DISTINCT, ELSE, EMPTY,
END, ENTRY, ESCAPE, EXISTS, EXP, EXTRACT, FALSE, FETCH, FLOOR, FROM,
FUNCTION, GROUP, HAVING, IN, INDEX, INNER, IS, JOIN, KEY, LEADING,
LEFT, LENGTH, LIKE, LOCAL, LN, LOCATE, LOWER, MAX, MEMBER, MIN, MOD,
NEW, NOT, NULL, NULLIF, OBJECT, OF, ON, OR, ORDER, OUTER, POSITION,
END, ENTRY, ESCAPE, EXISTS, EXP, EXTRACT, FALSE, FETCH, FIRST, FLOOR,
FROM, FUNCTION, GROUP, HAVING, IN, INDEX, INNER, IS, JOIN, KEY, LEADING,
LAST, LEFT, LENGTH, LIKE, LOCAL, LN, LOCATE, LOWER, MAX, MEMBER, MIN, MOD,
NEW, NOT, NULL, NULLS, NULLIF, OBJECT, OF, ON, OR, ORDER, OUTER, POSITION,
POWER, ROUND, SELECT, SET, SIGN, SIZE, SOME, SQRT, SUBSTRING, SUM,
THEN, TRAILING, TREAT, TRIM, TRUE, TYPE, UNKNOWN, UPDATE, UPPER,
VALUE, WHEN, WHERE.
Expand Down Expand Up @@ -2510,6 +2510,7 @@ orderby_clause ::= ORDER BY orderby_item {, orderby_item}*
orderby_item ::=
{state_field_path_expression | general_identification_variable | result_variable}
[ASC | DESC]
[NULLS {FIRST | LAST}]
----

An orderby_item must be one of the following:
Expand Down Expand Up @@ -2586,7 +2587,9 @@ ordering be used for the associated _orderby_item_; the keyword DESC
specifies that descending ordering be used. Ascending ordering is the
default.

SQL rules for the ordering of null values
The keyword NULLS specifies the ordering of null values, either FIRST or LAST.

If NULLS is not specified, SQL rules for the ordering of null values
apply: that is, all null values must appear before all non-null values
in the ordering or all null values must appear after all non-null values
in the ordering, but it is not specified which.
Expand Down Expand Up @@ -2985,6 +2988,7 @@ orderby_item ::=
general_identification_variable |
result_variable
[ASC | DESC]
[NULLS {FIRST | LAST}]
subquery ::= simple_select_clause subquery_from_clause [where_clause]
[groupby_clause] [having_clause]
subquery_from_clause ::=
Expand Down

0 comments on commit df94048

Please sign in to comment.