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

org.springframework.data.relational.core.sql.SelectBuilder Maven / Gradle / Ivy

There is a newer version: 3.3.2
Show newest version
/*
 * Copyright 2019-2023 the original author or authors.
 *
 * 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
 *
 *      https://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.
 */
package org.springframework.data.relational.core.sql;

import java.util.Collection;

/**
 * Entry point to construct a {@link Select} statement.
 *
 * @author Mark Paluch
 * @author Jens Schauder
 * @author Myeonghyeon Lee
 * @since 1.1
 * @see StatementBuilder
 */
public interface SelectBuilder {

	/**
	 * Apply a {@code TOP} clause given {@code count}.
	 *
	 * @param count the top count.
	 * @return {@code this} {@link SelectBuilder}.
	 */
	SelectBuilder top(int count);

	/**
	 * Include a {@link Expression} in the select list.
	 *
	 * @param expression the expression to include.
	 * @return {@code this} builder.
	 * @see Table#column(String)
	 */
	SelectAndFrom select(Expression expression);

	/**
	 * Include one or more {@link Expression}s in the select list.
	 *
	 * @param expressions the expressions to include.
	 * @return {@code this} builder.
	 * @see Table#columns(String...)
	 */
	SelectAndFrom select(Expression... expressions);

	/**
	 * Include one or more {@link Expression}s in the select list.
	 *
	 * @param expressions the expressions to include.
	 * @return {@code this} builder.
	 * @see Table#columns(String...)
	 */
	SelectAndFrom select(Collection expressions);

	/**
	 * Makes the select statement distinct
	 *
	 * @return {@code this} builder.
	 */
	SelectAndFrom distinct();

	/**
	 * Builder exposing {@code SELECT} and {@code FROM} methods.
	 */
	interface SelectAndFrom extends SelectFrom {

		/**
		 * Include a {@link Expression} in the select list. Multiple calls to this or other {@code select} methods keep
		 * adding items to the select list and do not replace previously contained items.
		 *
		 * @param expression the expression to include.
		 * @return {@code this} builder.
		 * @see Table#column(String)
		 */
		SelectFrom select(Expression expression);

		/**
		 * Include one or more {@link Expression}s in the select list. Multiple calls to this or other {@code select}
		 * methods keep adding items to the select list and do not replace previously contained items.
		 *
		 * @param expressions the expressions to include.
		 * @return {@code this} builder.
		 * @see Table#columns(String...)
		 */
		SelectFrom select(Expression... expressions);

		/**
		 * Include one or more {@link Expression}s in the select list. Multiple calls to this or other {@code select}
		 * methods keep adding items to the select list and do not replace previously contained items.
		 *
		 * @param expressions the expressions to include.
		 * @return {@code this} builder.
		 * @see Table#columns(String...)
		 */
		SelectFrom select(Collection expressions);

		/**
		 * Makes the select statement distinct
		 *
		 * @return {@code this} builder.
		 */
		SelectAndFrom distinct();

		/**
		 * Declare a {@link Table} to {@code SELECT … FROM}. Multiple calls to this or other {@code from} methods keep
		 * adding items to the select list and do not replace previously contained items.
		 *
		 * @param table the table name to {@code SELECT … FROM} must not be {@literal null} or empty.
		 * @return {@code this} builder.
		 * @see From
		 * @see SQL#table(String)
		 */
		@Override
		SelectFromAndJoin from(String table);

		/**
		 * Declare a {@link Table} to {@code SELECT … FROM}. Multiple calls to this or other {@code from} methods keep
		 * adding items to the select list and do not replace previously contained items.
		 *
		 * @param table the table to {@code SELECT … FROM} must not be {@literal null}.
		 * @return {@code this} builder.
		 * @see From
		 * @see SQL#table(String)
		 */
		@Override
		SelectFromAndJoin from(TableLike table);

		/**
		 * Declare one or more {@link Table}s to {@code SELECT … FROM}. Multiple calls to this or other {@code from} methods
		 * keep adding items to the select list and do not replace previously contained items.
		 *
		 * @param tables the tables to {@code SELECT … FROM} must not be {@literal null}.
		 * @return {@code this} builder.
		 * @see From
		 * @see SQL#table(String)
		 */
		@Override
		SelectFromAndJoin from(TableLike... tables);

		/**
		 * Declare one or more {@link Table}s to {@code SELECT … FROM}. Multiple calls to this or other {@code from} methods
		 * keep adding items to the select list and do not replace previously contained items.
		 *
		 * @param tables the tables to {@code SELECT … FROM} must not be {@literal null}.
		 * @return {@code this} builder.
		 * @see From
		 * @see SQL#table(String)
		 */
		@Override
		SelectFromAndJoin from(Collection tables);
	}

	/**
	 * Builder exposing {@code FROM} methods.
	 */
	interface SelectFrom extends BuildSelect {

		/**
		 * Declare a {@link Table} to {@code SELECT … FROM}. Multiple calls to this or other {@code from} methods keep
		 * adding items to the select list and do not replace previously contained items.
		 *
		 * @param table the table name to {@code SELECT … FROM} must not be {@literal null} or empty.
		 * @return {@code this} builder.
		 * @see From
		 * @see SQL#table(String)
		 */
		SelectFromAndOrderBy from(String table);

		/**
		 * Declare a {@link Table} to {@code SELECT … FROM}. Multiple calls to this or other {@code from} methods keep
		 * adding items to the select list and do not replace previously contained items.
		 *
		 * @param table the table to {@code SELECT … FROM} must not be {@literal null}.
		 * @return {@code this} builder.
		 * @see From
		 * @see SQL#table(String)
		 */
		SelectFromAndOrderBy from(TableLike table);

		/**
		 * Declare one or more {@link Table}s to {@code SELECT … FROM}. Multiple calls to this or other {@code from} methods
		 * keep adding items to the select list and do not replace previously contained items.
		 *
		 * @param tables the tables to {@code SELECT … FROM} must not be {@literal null}.
		 * @return {@code this} builder.
		 * @see From
		 * @see SQL#table(String)
		 */
		SelectFromAndOrderBy from(TableLike... tables);

		/**
		 * Declare one or more {@link Table}s to {@code SELECT … FROM}. Multiple calls to this or other {@code from} methods
		 * keep adding items to the select list and do not replace previously contained items.
		 *
		 * @param tables the tables to {@code SELECT … FROM} must not be {@literal null}.
		 * @return {@code this} builder.
		 * @see From
		 * @see SQL#table(String)
		 */
		SelectFromAndOrderBy from(Collection tables);
	}

	/**
	 * Builder exposing {@code FROM}, {@code JOIN}, {@code WHERE}, {@code LIMIT/OFFSET} and {@code LOCK} methods.
	 */
	interface SelectFromAndOrderBy extends SelectFrom, SelectOrdered, SelectLimitOffset, SelectLock, BuildSelect {

		@Override
		SelectFromAndOrderBy limitOffset(long limit, long offset);

		@Override
		SelectFromAndOrderBy limit(long limit);

		@Override
		SelectFromAndOrderBy offset(long offset);

		@Override
		SelectFromAndOrderBy from(String table);

		@Override
		SelectFromAndOrderBy from(TableLike table);

		@Override
		SelectFromAndOrderBy from(TableLike... tables);

		@Override
		SelectFromAndOrderBy from(Collection tables);

		@Override
		SelectFromAndOrderBy orderBy(Column... columns);

		@Override
		SelectFromAndOrderBy orderBy(OrderByField... orderByFields);

		@Override
		SelectFromAndOrderBy orderBy(Collection orderByFields);
	}

	/**
	 * Builder exposing {@code FROM}, {@code JOIN}, {@code WHERE}, {@code LIMIT/OFFSET} and {@code LOCK} methods.
	 */
	interface SelectFromAndJoin
			extends SelectFromAndOrderBy, BuildSelect, SelectJoin, SelectWhere, SelectLimitOffset, SelectLock {

		/**
		 * Declare a {@link Table} to {@code SELECT … FROM}. Multiple calls to this or other {@code from} methods keep
		 * adding items to the select list and do not replace previously contained items.
		 *
		 * @param table the table to {@code SELECT … FROM} must not be {@literal null}.
		 * @return {@code this} builder.
		 * @see From
		 * @see SQL#table(String)
		 */
		@Override
		SelectFromAndJoin from(TableLike table);

		/**
		 * Declare one or more {@link Table}s to {@code SELECT … FROM}. Multiple calls to this or other {@code from} methods
		 * keep adding items to the select list and do not replace previously contained items.
		 *
		 * @param tables the tables to {@code SELECT … FROM} must not be {@literal null}.
		 * @return {@code this} builder.
		 * @see From
		 * @see SQL#table(String)
		 */
		@Override
		SelectFromAndJoin from(TableLike... tables);

		/**
		 * Declare one or more {@link Table}s to {@code SELECT … FROM}. Multiple calls to this or other {@code from} methods
		 * keep adding items to the select list and do not replace previously contained items.
		 *
		 * @param tables the tables to {@code SELECT … FROM} must not be {@literal null}.
		 * @return {@code this} builder.
		 * @see From
		 * @see SQL#table(String)
		 */
		@Override
		SelectFromAndJoin from(Collection tables);

		/**
		 * Apply {@code limit} and {@code offset} parameters to the select statement. To read the first 20 rows from start
		 * use {@code limitOffset(20, 0)}. to read the next 20 use {@code limitOffset(20, 20)}.
		 *
		 * @param limit rows to read.
		 * @param offset row offset, zero-based.
		 * @return {@code this} builder.
		 */
		SelectFromAndJoin limitOffset(long limit, long offset);

		/**
		 * Apply a limit of rows to read.
		 *
		 * @param limit rows to read.
		 * @return {@code this} builder.
		 */
		SelectFromAndJoin limit(long limit);

		/**
		 * Apply an offset where to start reading rows.
		 *
		 * @param offset start offset.
		 * @return {@code this} builder.
		 */
		SelectFromAndJoin offset(long offset);
	}

	/**
	 * Builder exposing {@code FROM}, {@code WHERE}, {@code LIMIT/OFFSET}, JOIN {@code AND} and {@code LOCK} continuation
	 * methods.
	 */
	interface SelectFromAndJoinCondition
			extends BuildSelect, SelectJoin, SelectWhere, SelectOnCondition, SelectLimitOffset, SelectLock {

		/**
		 * Apply {@code limit} and {@code offset} parameters to the select statement. To read the first 20 rows from start
		 * use {@code limitOffset(20, 0)}. to read the next 20 use {@code limitOffset(20, 20)}.
		 *
		 * @param limit rows to read.
		 * @param offset row offset, zero-based.
		 * @return {@code this} builder.
		 */
		SelectFromAndJoin limitOffset(long limit, long offset);

		/**
		 * Apply a limit of rows to read.
		 *
		 * @param limit rows to read.
		 * @return {@code this} builder.
		 */
		SelectFromAndJoin limit(long limit);

		/**
		 * Apply an offset where to start reading rows.
		 *
		 * @param offset start offset.
		 * @return {@code this} builder.
		 */
		SelectFromAndJoin offset(long offset);
	}

	/**
	 * Limit/offset methods.
	 */
	interface SelectLimitOffset {

		/**
		 * Apply {@code limit} and {@code offset} parameters to the select statement. To read the first 20 rows from start
		 * use {@code limitOffset(20, 0)}. to read the next 20 use {@code limitOffset(20, 20)}.
		 *
		 * @param limit rows to read.
		 * @param offset row offset, zero-based.
		 * @return {@code this} builder.
		 */
		SelectLimitOffset limitOffset(long limit, long offset);

		/**
		 * Apply a limit of rows to read.
		 *
		 * @param limit rows to read.
		 * @return {@code this} builder.
		 */
		SelectLimitOffset limit(long limit);

		/**
		 * Apply an offset where to start reading rows.
		 *
		 * @param offset start offset.
		 * @return {@code this} builder.
		 */
		SelectLimitOffset offset(long offset);
	}

	/**
	 * Builder exposing {@code ORDER BY} and {@code LOCK} methods.
	 */
	interface SelectOrdered extends SelectLock, BuildSelect {

		/**
		 * Add one or more {@link Column columns} to order by.
		 *
		 * @param columns the columns to order by.
		 * @return {@code this} builder.
		 */
		SelectOrdered orderBy(Column... columns);

		/**
		 * Add one or more {@link OrderByField order by fields}.
		 *
		 * @param orderByFields the fields to order by.
		 * @return {@code this} builder.
		 */
		SelectOrdered orderBy(OrderByField... orderByFields);

		/**
		 * Add one or more {@link OrderByField order by fields}.
		 *
		 * @param orderByFields the fields to order by.
		 * @return {@code this} builder.
		 */
		SelectOrdered orderBy(Collection orderByFields);
	}

	/**
	 * Interface exposing {@code WHERE}, {@code LOCK} methods.
	 */
	interface SelectWhere extends SelectOrdered, SelectLock, BuildSelect {

		/**
		 * Apply a {@code WHERE} clause.
		 *
		 * @param condition the {@code WHERE} condition.
		 * @return {@code this} builder.
		 * @see Where
		 * @see Condition
		 */
		SelectWhereAndOr where(Condition condition);
	}

	/**
	 * Interface exposing {@code AND}/{@code OR} combinator methods for {@code WHERE} {@link Condition}s.
	 */
	interface SelectWhereAndOr extends SelectOrdered, SelectLock, BuildSelect {

		/**
		 * Combine the previous {@code WHERE} {@link Condition} using {@code AND}.
		 *
		 * @param condition the condition, must not be {@literal null}.
		 * @return {@code this} builder.
		 * @see Condition#and(Condition)
		 */
		SelectWhereAndOr and(Condition condition);

		/**
		 * Combine the previous {@code WHERE} {@link Condition} using {@code OR}.
		 *
		 * @param condition the condition, must not be {@literal null}.
		 * @return {@code this} builder.
		 * @see Condition#or(Condition)
		 */
		SelectWhereAndOr or(Condition condition);
	}

	/**
	 * Interface exposing {@code JOIN} methods.
	 */
	interface SelectJoin extends SelectLock, BuildSelect {

		/**
		 * Declare a {@code JOIN} {@code table}.
		 *
		 * @param table name of the table, must not be {@literal null} or empty.
		 * @return {@code this} builder.
		 * @see Join
		 * @see SQL#table(String)
		 */
		SelectOn join(String table);

		/**
		 * Declare a {@code JOIN} {@link Table}.
		 *
		 * @param table name of the table, must not be {@literal null}.
		 * @return {@code this} builder.
		 * @see Join
		 * @see SQL#table(String)
		 */
		SelectOn join(TableLike table);

		/**
		 * Declare a {@code LEFT OUTER JOIN} {@link Table}.
		 *
		 * @param table must not be {@literal null}.
		 * @return {@code this} builder.
		 * @see Join
		 * @see SQL#table(String)
		 */
		SelectOn leftOuterJoin(TableLike table);

		/**
		 * Declar a join, where the join type ({@code INNER}, {@code LEFT OUTER}, {@code RIGHT OUTER}, {@code FULL OUTER})
		 * is specified by an extra argument.
		 * 
		 * @param table the table to join. Must not be {@literal null}.
		 * @param joinType the type of joi. Must not be {@literal null}.
		 * @return {@code this} builder.
		 */
		SelectOn join(TableLike table, Join.JoinType joinType);
	}

	/**
	 * Interface exposing {@code ON} methods to declare {@code JOIN} relationships.
	 */
	interface SelectOn {

		/**
		 * Declare the source column in the {@code JOIN}.
		 *
		 * @param column the source column, must not be {@literal null} or empty.
		 * @return {@code this} builder.
		 * @see Table#column(String)
		 */
		SelectOnConditionComparison on(Expression column);

		/**
		 * Declare a join {@link Condition condition} in one step. Using conditions allows more flexibility in comparison to
		 * {@link #on(Expression)} which only allows for equality comparisons chained together with {@code AND}.
		 *
		 * @param condition must not be {@literal null}.
		 * @return {@code this} builder.
		 * @see Conditions
		 * @since 2.3
		 */
		SelectFromAndJoinCondition on(Condition condition);
	}

	/**
	 * Interface declaring the target column comparison relationship.
	 */
	interface SelectOnConditionComparison {

		/**
		 * Declare an equals {@link Condition} between the source column and the target {@link Column}.
		 *
		 * @param column the target column, must not be {@literal null}.
		 * @return {@code this} builder.
		 * @see Table#column(String)
		 */
		SelectFromAndJoinCondition equals(Expression column);
	}

	/**
	 * Builder exposing JOIN and {@code JOIN … ON} continuation methods.
	 */
	interface SelectOnCondition extends SelectJoin, SelectLock, BuildSelect {

		/**
		 * Declare an additional source column in the {@code JOIN}.
		 *
		 * @param column the column, must not be {@literal null}.
		 * @return {@code this} builder.
		 * @see Table#column(String)
		 */
		SelectOnConditionComparison and(Expression column);
	}

	/**
	 * Lock methods.
	 */
	interface SelectLock extends BuildSelect {

		/**
		 * Apply lock to read.
		 *
		 * @param lockMode lockMode to read.
		 * @return {@code this} builder.
		 */
		SelectLock lock(LockMode lockMode);
	}

	/**
	 * Interface exposing the {@link Select} build method.
	 */
	interface BuildSelect {

		/**
		 * Build the {@link Select} statement and verify basic relationship constraints such as all referenced columns have
		 * a {@code FROM} or {@code JOIN} table import.
		 *
		 * @return the build and immutable {@link Select} statement.
		 */
		Select build();
	}
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy