All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.jooq.SelectOrderByStep Maven / Gradle / Ivy

There is a newer version: 3.19.16
Show newest version
/*
 * 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 field19, OrderField field20); /** * Add an ORDER BY clause to the query. */ @NotNull @CheckReturnValue @Support SelectSeekStep21 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, OrderField field20, OrderField field21); /** * Add an ORDER BY clause to the query. */ @NotNull @CheckReturnValue @Support SelectSeekStep22 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, OrderField field20, OrderField field21, OrderField field22); /** * Add an ORDER BY clause to the query */ @NotNull @CheckReturnValue @Support SelectSeekStepN orderBy(OrderField... fields); /** * Add an ORDER BY clause to the query */ @NotNull @CheckReturnValue @Support SelectSeekStepN orderBy(Collection> fields); /** * Add an ORDER BY clause to the query *

* Indexes start at 1 in SQL! *

* Note, you can use orderBy(DSL.val(1).desc()) or * orderBy(DSL.literal(1).desc()) to apply descending * ordering */ @NotNull @CheckReturnValue @Support SelectLimitStep orderBy(int... fieldIndexes); }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy