org.jooq.SelectOrderByStep Maven / Gradle / Ivy
/*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
* Other licenses:
* -----------------------------------------------------------------------------
* Commercial licenses for this work are available. These replace the above
* Apache-2.0 license and offer limited warranties, support, maintenance, and
* commercial database integrations.
*
* For more information, please visit: http://www.jooq.org/licenses
*
*
*
*
*
*
*
*
*
*
*
*
*
*
*
*
*/
package org.jooq;
import org.jetbrains.annotations.*;
import static org.jooq.SQLDialect.CUBRID;
// ...
// ...
import java.util.Collection;
/**
* This type is used for the {@link Select}'s DSL API when selecting generic
* {@link Record} types.
*
* Example:
* -- get all authors' first and last names, and the number
* -- of books they've written in German, if they have written
* -- more than five books in German in the last three years
* -- (from 2011), and sort those authors by last names
* -- limiting results to the second and third row
*
* SELECT T_AUTHOR.FIRST_NAME, T_AUTHOR.LAST_NAME, COUNT(*)
* FROM T_AUTHOR
* JOIN T_BOOK ON T_AUTHOR.ID = T_BOOK.AUTHOR_ID
* WHERE T_BOOK.LANGUAGE = 'DE'
* AND T_BOOK.PUBLISHED > '2008-01-01'
* GROUP BY T_AUTHOR.FIRST_NAME, T_AUTHOR.LAST_NAME
* HAVING COUNT(*) > 5
* ORDER BY T_AUTHOR.LAST_NAME ASC NULLS FIRST
* LIMIT 2
* OFFSET 1
* FOR UPDATE
* OF FIRST_NAME, LAST_NAME
* NO WAIT
*
Its equivalent in jOOQ
* create.select(TAuthor.FIRST_NAME, TAuthor.LAST_NAME, create.count())
* .from(T_AUTHOR)
* .join(T_BOOK).on(TBook.AUTHOR_ID.equal(TAuthor.ID))
* .where(TBook.LANGUAGE.equal("DE"))
* .and(TBook.PUBLISHED.greaterThan(parseDate('2008-01-01')))
* .groupBy(TAuthor.FIRST_NAME, TAuthor.LAST_NAME)
* .having(create.count().greaterThan(5))
* .orderBy(TAuthor.LAST_NAME.asc().nullsFirst())
* .limit(2)
* .offset(1)
* .forUpdate()
* .of(TAuthor.FIRST_NAME, TAuthor.LAST_NAME)
* .noWait();
*
Refer to the manual for more details
*
*
Referencing XYZ*Step
types directly from client code
*
* It is usually not recommended to reference any XYZ*Step
types
* directly from client code, or assign them to local variables. When writing
* dynamic SQL, creating a statement's components dynamically, and passing them
* to the DSL API statically is usually a better choice. See the manual's
* section about dynamic SQL for details: https://www.jooq.org/doc/latest/manual/sql-building/dynamic-sql.
*
* Drawbacks of referencing the XYZ*Step
types directly:
*
* - They're operating on mutable implementations (as of jOOQ 3.x)
* - They're less composable and not easy to get right when dynamic SQL gets
* complex
* - They're less readable
* - They might have binary incompatible changes between minor releases
*
*
* @author Lukas Eder
*/
public interface SelectOrderByStep extends SelectLimitStep {
/**
* Add an ORDER BY
clause to the query.
*/
@NotNull @CheckReturnValue
@Support
SelectSeekStep1 orderBy(OrderField field1);
/**
* Add an ORDER BY
clause to the query.
*/
@NotNull @CheckReturnValue
@Support
SelectSeekStep2 orderBy(OrderField field1, OrderField field2);
/**
* Add an ORDER BY
clause to the query.
*/
@NotNull @CheckReturnValue
@Support
SelectSeekStep3 orderBy(OrderField field1, OrderField field2, OrderField field3);
/**
* Add an ORDER BY
clause to the query.
*/
@NotNull @CheckReturnValue
@Support
SelectSeekStep4 orderBy(OrderField field1, OrderField field2, OrderField field3, OrderField field4);
/**
* Add an ORDER BY
clause to the query.
*/
@NotNull @CheckReturnValue
@Support
SelectSeekStep5 orderBy(OrderField field1, OrderField field2, OrderField field3, OrderField field4, OrderField field5);
/**
* Add an ORDER BY
clause to the query.
*/
@NotNull @CheckReturnValue
@Support
SelectSeekStep6 orderBy(OrderField field1, OrderField field2, OrderField field3, OrderField field4, OrderField field5, OrderField field6);
/**
* Add an ORDER BY
clause to the query.
*/
@NotNull @CheckReturnValue
@Support
SelectSeekStep7 orderBy(OrderField field1, OrderField field2, OrderField field3, OrderField field4, OrderField field5, OrderField field6, OrderField field7);
/**
* Add an ORDER BY
clause to the query.
*/
@NotNull @CheckReturnValue
@Support
SelectSeekStep8 orderBy(OrderField field1, OrderField field2, OrderField field3, OrderField field4, OrderField field5, OrderField field6, OrderField field7, OrderField field8);
/**
* Add an ORDER BY
clause to the query.
*/
@NotNull @CheckReturnValue
@Support
SelectSeekStep9 orderBy(OrderField field1, OrderField field2, OrderField field3, OrderField field4, OrderField field5, OrderField field6, OrderField field7, OrderField field8, OrderField field9);
/**
* Add an ORDER BY
clause to the query.
*/
@NotNull @CheckReturnValue
@Support
SelectSeekStep10 orderBy(OrderField field1, OrderField field2, OrderField field3, OrderField field4, OrderField field5, OrderField field6, OrderField field7, OrderField field8, OrderField field9, OrderField field10);
/**
* Add an ORDER BY
clause to the query.
*/
@NotNull @CheckReturnValue
@Support
SelectSeekStep11 orderBy(OrderField field1, OrderField field2, OrderField field3, OrderField field4, OrderField field5, OrderField field6, OrderField field7, OrderField field8, OrderField field9, OrderField field10, OrderField field11);
/**
* Add an ORDER BY
clause to the query.
*/
@NotNull @CheckReturnValue
@Support
SelectSeekStep12 orderBy(OrderField field1, OrderField field2, OrderField field3, OrderField field4, OrderField field5, OrderField field6, OrderField field7, OrderField field8, OrderField field9, OrderField field10, OrderField field11, OrderField field12);
/**
* Add an ORDER BY
clause to the query.
*/
@NotNull @CheckReturnValue
@Support
SelectSeekStep13 orderBy(OrderField field1, OrderField field2, OrderField field3, OrderField field4, OrderField field5, OrderField field6, OrderField field7, OrderField field8, OrderField field9, OrderField field10, OrderField field11, OrderField field12, OrderField field13);
/**
* Add an ORDER BY
clause to the query.
*/
@NotNull @CheckReturnValue
@Support
SelectSeekStep14 orderBy(OrderField field1, OrderField field2, OrderField field3, OrderField field4, OrderField field5, OrderField field6, OrderField field7, OrderField field8, OrderField field9, OrderField field10, OrderField field11, OrderField field12, OrderField field13, OrderField field14);
/**
* Add an ORDER BY
clause to the query.
*/
@NotNull @CheckReturnValue
@Support
SelectSeekStep15 orderBy(OrderField field1, OrderField field2, OrderField field3, OrderField field4, OrderField field5, OrderField field6, OrderField field7, OrderField field8, OrderField field9, OrderField field10, OrderField field11, OrderField field12, OrderField field13, OrderField field14, OrderField field15);
/**
* Add an ORDER BY
clause to the query.
*/
@NotNull @CheckReturnValue
@Support
SelectSeekStep16 orderBy(OrderField field1, OrderField field2, OrderField field3, OrderField field4, OrderField field5, OrderField field6, OrderField field7, OrderField field8, OrderField field9, OrderField field10, OrderField field11, OrderField field12, OrderField field13, OrderField field14, OrderField field15, OrderField field16);
/**
* Add an ORDER BY
clause to the query.
*/
@NotNull @CheckReturnValue
@Support
SelectSeekStep17 orderBy(OrderField field1, OrderField field2, OrderField field3, OrderField field4, OrderField field5, OrderField field6, OrderField field7, OrderField field8, OrderField field9, OrderField field10, OrderField field11, OrderField field12, OrderField field13, OrderField field14, OrderField field15, OrderField field16, OrderField field17);
/**
* Add an ORDER BY
clause to the query.
*/
@NotNull @CheckReturnValue
@Support
SelectSeekStep18 orderBy(OrderField field1, OrderField field2, OrderField field3, OrderField field4, OrderField field5, OrderField field6, OrderField field7, OrderField field8, OrderField field9, OrderField field10, OrderField field11, OrderField field12, OrderField field13, OrderField field14, OrderField field15, OrderField field16, OrderField field17, OrderField field18);
/**
* Add an ORDER BY
clause to the query.
*/
@NotNull @CheckReturnValue
@Support
SelectSeekStep19 orderBy(OrderField field1, OrderField field2, OrderField field3, OrderField field4, OrderField field5, OrderField field6, OrderField field7, OrderField field8, OrderField field9, OrderField field10, OrderField field11, OrderField field12, OrderField field13, OrderField field14, OrderField field15, OrderField field16, OrderField field17, OrderField field18, OrderField field19);
/**
* Add an ORDER BY
clause to the query.
*/
@NotNull @CheckReturnValue
@Support
SelectSeekStep20 orderBy(OrderField field1, OrderField field2, OrderField field3, OrderField field4, OrderField field5, OrderField field6, OrderField field7, OrderField field8, OrderField field9, OrderField field10, OrderField field11, OrderField field12, OrderField field13, OrderField field14, OrderField field15, OrderField field16, OrderField field17, OrderField field18, OrderField