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

org.dbflute.cbean.sqlclause.SqlClause Maven / Gradle / Ivy

/*
 * Copyright 2014-2017 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
 *
 *     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.
 */
package org.dbflute.cbean.sqlclause;

import java.util.List;
import java.util.Map;
import java.util.Set;

import org.dbflute.cbean.chelper.HpCBPurpose;
import org.dbflute.cbean.chelper.HpDerivingSubQueryInfo;
import org.dbflute.cbean.chelper.HpInvalidQueryInfo;
import org.dbflute.cbean.cipher.ColumnFunctionCipher;
import org.dbflute.cbean.cipher.GearedCipherManager;
import org.dbflute.cbean.ckey.ConditionKey;
import org.dbflute.cbean.coption.ConditionOption;
import org.dbflute.cbean.coption.LikeSearchOption;
import org.dbflute.cbean.coption.ScalarSelectOption;
import org.dbflute.cbean.cvalue.ConditionValue;
import org.dbflute.cbean.dream.SpecifiedColumn;
import org.dbflute.cbean.ordering.ManualOrderOption;
import org.dbflute.cbean.sqlclause.clause.ClauseLazyReflector;
import org.dbflute.cbean.sqlclause.clause.SelectClauseType;
import org.dbflute.cbean.sqlclause.join.FixedConditionLazyChecker;
import org.dbflute.cbean.sqlclause.join.FixedConditionResolver;
import org.dbflute.cbean.sqlclause.join.LeftOuterJoinInfo;
import org.dbflute.cbean.sqlclause.orderby.OrderByClause;
import org.dbflute.cbean.sqlclause.orderby.OrderByElement;
import org.dbflute.cbean.sqlclause.query.QueryClause;
import org.dbflute.cbean.sqlclause.query.QueryClauseFilter;
import org.dbflute.cbean.sqlclause.query.QueryUsedAliasInfo;
import org.dbflute.cbean.sqlclause.select.SelectedRelationColumn;
import org.dbflute.cbean.sqlclause.select.SpecifiedSelectColumnHandler;
import org.dbflute.cbean.sqlclause.union.UnionClauseProvider;
import org.dbflute.dbmeta.info.ColumnInfo;
import org.dbflute.dbmeta.info.ForeignInfo;
import org.dbflute.dbmeta.name.ColumnRealName;
import org.dbflute.dbmeta.name.ColumnSqlName;
import org.dbflute.dbway.DBWay;

/**
 * The interface of SQL clause. 
* *

And this also has a role of a container for common info * between the top level condition-bean and related condition-queries.

* *

It has many histories... e.g. structures, method names, * it might be hard to read but no big refactoring * because the histories and memories are also documents.

* * @author jflute */ public interface SqlClause { // =================================================================================== // Definition // ========== /** The delimiter of relation path. The relation path is e.g. _0_3 */ String RELATION_PATH_DELIMITER = "_"; /** The alias name of base point table for on-query. */ String BASE_POINT_ALIAS_NAME = "dfloc"; /** The entity number of base point table for internal handling. */ String BASE_POINT_HANDLING_ENTITY_NO = "loc00"; // =================================================================================== // SubQuery Level // ============== /** * Get the hierarchy level of sub-query. * @return The hierarchy level of sub-query. (NotMinus: if zero, not for sub-query) */ int getSubQueryLevel(); /** * Set up this SQL for sub-query. * @param subQueryLevel The hierarchy level of sub-query. (NotMinus: if zero, not for sub-query) */ void setupForSubQuery(int subQueryLevel); /** * Is this SQL for sub-query? * @return The determination, true or false. */ boolean isForSubQuery(); // =================================================================================== // Whole Clause // ============ // ----------------------------------------------------- // Complete Clause // --------------- /** * Get the clause of all parts. *
     * select [base-table-columns], [join-table-columns]
     *   from [base-table] left outer join [join-table] [join-alias] on [join-condition]
     *  where [base-table].[column] = [value] and [join-alias].[column] is null
     *  order by [base-table].[column] asc, [join-alias].[column] desc
     *  for update
     * 
* @return The clause of all parts. (NotNull) */ String getClause(); // ----------------------------------------------------- // Fragment Clause // --------------- /** * Get from-where clause without select and orderBy and sqlSuffix.
* Basically for subQuery and selectCount.
* You should handle UnionSelectClauseMark and UnionWhereClauseMark and UnionWhereFirstConditionMark in clause. * @return The 'from-where' clause(contains union) without 'select' and 'orderBy' and 'sqlSuffix'. (NotNull) */ String getClauseFromWhereWithUnionTemplate(); /** * Get from-where clause without select and orderBy and sqlSuffix as template.
* Basically for subQuery and selectCount.
* You should handle UnionSelectClauseMark and UnionWhereClauseMark and UnionWhereFirstConditionMark * and WhereClauseMark and WhereFirstConditionMark in clause. * @return The 'from-where' clause(contains union) without 'select' and 'orderBy' and 'sqlSuffix'. (NotNull) */ String getClauseFromWhereWithWhereUnionTemplate(); // =================================================================================== // Clause Parts // ============ /** * Get the clause of 'select'. This is an internal method. * @return The clause of select. {[select ...] from table...} (NotNull) */ String getSelectClause(); /** * Get the map of select index by key name of select column.
* map:{entityNo(e.g. loc00 or _0_3) = map:{selectColumnKeyName = selectIndex}} * @return The map of select index. (NullAllowed: null means lazy-loaded not yet or select index is disabled) */ Map> getSelectIndexMap(); /** * Get the map of key name of select column by on-query name.
* map:{onQueryAlias = selectColumnKeyName}} * @return The map of key name. (NullAllowed: null means lazy-loaded not yet or select index is disabled) */ Map getSelectColumnKeyNameMap(); /** * Change limit size of alias name. * @param aliasNameLimitSize The limit size of alias name. (NotMinus, NotZero) */ void changeAliasNameLimitSize(int aliasNameLimitSize); /** * Disable select index. */ void disableSelectIndex(); /** * Get the hint of 'select'. This is an internal method. * @return The hint of 'select'. {select [select-hint] * from table...} (NotNull) */ String getSelectHint(); /** * Get the clause of 'from'. This is an internal method. * @return The clause of 'from'. (NotNull) */ String getFromClause(); /** * Get the clause of from-base-table. This is an internal method. * @return The hint of from-base-table. {select * from table [from-base-table-hint] where ...} (NotNull) */ String getFromBaseTableHint(); /** * Get the hint of 'from'. This is an internal method. * @return The hint of 'from'. {select * from table left outer join ... on ... [from-hint] where ...} (NotNull) */ String getFromHint(); /** * Get the clause of 'where'. This is an internal method. * @return The clause of 'where'. (NotNull) */ String getWhereClause(); /** * Get the clause of 'order-by'. This is an internal method. * @return The clause of 'order-by'. (NotNull) */ String getOrderByClause(); /** * Get the suffix of SQL. This is an internal method. * @return The suffix of SQL. {select * from table where ... order by ... [sql-suffix]} (NotNull) */ String getSqlSuffix(); // =================================================================================== // Selected Relation // ================= /** * Register selected relation. * @param foreignTableAliasName The alias name of foreign table. (NotNull) * @param localTableDbName The table DB name of local. (NotNull) * @param foreignPropertyName The property name of foreign table. (NotNull) * @param localRelationPath The path of local relation. (NullAllowed) * @param foreignRelationPath The path of foreign relation, same as relation No suffix. e.g. _3, _7_2 (NotNull) */ void registerSelectedRelation(String foreignTableAliasName, String localTableDbName, String foreignPropertyName, String localRelationPath, String foreignRelationPath); /** * Translate selected relation path (foreignRelationPath: relationNoSuffix) to relation property name (foreignPropertyName). * @param foreignRelationPath The relation path of foreign property (relationNoSuffix). e.g. _3, _7_2 (NotNull) * @return The name of foreign property, (foreignPropertyName). (NotNull) */ String translateSelectedRelationPathToPropName(String foreignRelationPath); /** * Translate selected relation path (foreignRelationPath: relationNoSuffix) to foreign table alias name (foreignTableAliasName). * @param foreignRelationPath The relation path of foreign property (relationNoSuffix). e.g. _3, _7_2 (NotNull) * @return The alias name of foreign table (foreignTableAliasName). (NotNull) */ String translateSelectedRelationPathToTableAlias(String foreignRelationPath); /** * Get the count of selected relation. * @return The integer of count. (NotMinus) */ int getSelectedRelationCount(); /** * Is the selected relation empty? * @return The determination, true or false. */ boolean isSelectedRelationEmpty(); /** * Is the relation selected? * @param foreignRelationPath The path of foreign relation, same as relation No suffix. e.g. _3, _7_2 (NotNull) * @return The determination, true or false. */ boolean hasSelectedRelation(String foreignRelationPath); /** * Get the map of selected relation column.
* Basically internal but public for analyzing. * @return The map of selected relation column. map:{foreignTableAliasName : map:{columnName : selectedRelationColumn}} (NotNull) */ Map> getSelectedRelationColumnMap(); /** * Does the relation connect to selected next relation? * @param foreignRelationPath The path of foreign relation, same as relation No suffix. e.g. _3, _7_2 (NotNull) * @return The determination, true or false. */ boolean isSelectedNextConnectingRelation(String foreignRelationPath); // =================================================================================== // OuterJoin // ========= // ----------------------------------------------------- // Registration // ------------ /** * Register outer-join.
* The fixed-conditions are located on on-clause. * @param foreignAliasName The alias name of foreign table. {left outer join [foreignTableDbName] [foreignAliasName]} (NotNull, Unique) * @param foreignTableDbName The DB name of foreign table. {left outer join [foreignTableDbName] [foreignAliasName]} (NotNull) * @param localAliasName The alias name of local table. {[localTableDbName] [localAliasName] left outer join} (NotNull) * @param localTableDbName The DB name of local table. {[localTableDbName] [localAliasName] left outer join} (NotNull) * @param joinOnMap The map of join condition on on-clause. (NotNull) * @param relationPath The path of relation. e.g. _1_3 (NotNull) * @param foreignInfo The information of foreign relation corresponding to this join. (NotNull) * @param fixedCondition The fixed condition on on-clause. (NullAllowed: if null, means no fixed condition) * @param fixedConditionResolver The resolver for variables on fixed-condition. (NullAllowed) */ void registerOuterJoin(String foreignAliasName, String foreignTableDbName, String localAliasName, String localTableDbName, Map joinOnMap, String relationPath, ForeignInfo foreignInfo, String fixedCondition, FixedConditionResolver fixedConditionResolver); /** * Register outer-join using in-line view for fixed-conditions.
* The fixed-conditions are located on in-line view. * @param foreignAliasName The alias name of foreign table. {left outer join [foreignTableDbName] [foreignAliasName]} (NotNull, Unique) * @param foreignTableDbName The DB name of foreign table. {left outer join [foreignTableDbName] [foreignAliasName]} (NotNull) * @param localAliasName The alias name of local table. {[localTableDbName] [localAliasName] left outer join} (NotNull) * @param localTableDbName The DB name of local table. {[localTableDbName] [localAliasName] left outer join} (NotNull) * @param joinOnMap The map of join condition on on-clause. (NotNull) * @param relationPath The path of relation. e.g. _1_3 (NotNull) * @param foreignInfo The information of foreign relation corresponding to this join. (NotNull) * @param fixedCondition The fixed condition on in-line view. (NullAllowed: if null, means no fixed condition) * @param fixedConditionResolver The resolver for variables on fixed-condition. (NullAllowed) */ void registerOuterJoinFixedInline(String foreignAliasName, String foreignTableDbName, String localAliasName, String localTableDbName, Map joinOnMap, String relationPath, ForeignInfo foreignInfo, String fixedCondition, FixedConditionResolver fixedConditionResolver); /** * Register the lazy checker for the fixed condition.
* This is called when building SQL clause. * @param checker The callback instance of checker. (NotNull) */ void registerFixedConditionLazyChecker(FixedConditionLazyChecker checker); // ----------------------------------------------------- // OuterJoin Attribute // ------------------- /** * Get the information of left-outer-join.
* Basically internal but public for analyzing. * @return The map of left-outer-join info. map:{ foreignAliasName : leftOuterJoinInfo } (NotNull) */ Map getOuterJoinMap(); /** * Does outer-join (at least one) exist? (contains inner-join) * @return The determination, true or false. */ boolean hasOuterJoin(); /** * Can it use the relation cache for entity mapping? * @param relationPath The path of relation. e.g. _1_3 (NotNull) * @return The determination, true or false. */ boolean canUseRelationCache(String relationPath); /** * Is the relation under over-relation? * @param relationPath The path of relation. e.g. _1_3 (NotNull) * @return The determination, true or false. */ boolean isUnderOverRelation(String relationPath); // ----------------------------------------------------- // InnerJoin Handling // ------------------ /** * Change the join type for the relation to inner join manually. * @param foreignAliasName The foreign alias name of join table. (NotNull and Unique per invoking method) */ void changeToInnerJoin(String foreignAliasName); // ----------------------------------------------------- //   InnerJoin AutoDetect // -------------------- // has several items of inner-join auto-detected /** * Enable to auto-detect joins that can be (all type) inner-join.
* You should call this before registrations of where clause. * (actually you can call before selecting but it's a fixed specification for user) */ void enableInnerJoinAutoDetect(); /** * Disable auto-detecting inner-join.
* You should call this before registrations of where clause. */ void disableInnerJoinAutoDetect(); // ----------------------------------------------------- // StructuralPossible InnerJoin // ---------------------------- // one of inner-join auto-detect /** * Enable to auto-detect joins that can be structure-possible inner-join.
* You should call this before registrations of where clause. * (actually you can call before selecting but it's a fixed specification for user) */ void enableStructuralPossibleInnerJoin(); /** * Disable auto-detecting structural-possible inner-join.
* You should call this before registrations of where clause. */ void disableStructuralPossibleInnerJoin(); /** * Does it allow to auto-detect structure-possible inner-join? * @return Determination. (true or false) */ boolean isStructuralPossibleInnerJoinEnabled(); // ----------------------------------------------------- // WhereUsed InnerJoin // ------------------- // one of inner-join auto-detect /** * Enable to auto-detect joins that can be where-used inner-join.
* You should call this before registrations of where clause. */ void enableWhereUsedInnerJoin(); /** * Disable auto-detecting where-used inner-join. * You should call this before registrations of where clause. */ void disableWhereUsedInnerJoin(); /** * Does it allow to auto-detect where-used inner-join? * @return Determination. (true or false) */ boolean isWhereUsedInnerJoinEnabled(); // =================================================================================== // Where // ===== // ----------------------------------------------------- // Registration // ------------ /** * Register 'where' clause. * @param columnRealName The real name of column. {[alias-name].[column-name]}. (NotNull) * @param key The key of condition. (NotNull) * @param value The value of condition. (NotNull) * @param cipher The cipher of column by function. (NullAllowed) * @param option The option of condition. (NullAllowed) * @param usedAliasName The alias name of table used on the where clause. (NotNull) */ void registerWhereClause(ColumnRealName columnRealName, ConditionKey key, ConditionValue value, ColumnFunctionCipher cipher, ConditionOption option, String usedAliasName); /** * Register 'where' clause.
* The join of the alias, if it's a relation condition, may have a chance to be inner-join. * @param clause The string clause of 'where'. (NotNull) * @param usedAliasName The alias name of table used on the where clause. (NotNull) */ void registerWhereClause(String clause, String usedAliasName); /** * Register 'where' clause.
* You can control the inner-join possibility. * @param clause The string clause of 'where'. (NotNull) * @param usedAliasName The alias name of table used on the where clause. (NotNull) * @param noWayInner No way, to be inner-join for the join of the alias? */ void registerWhereClause(String clause, String usedAliasName, boolean noWayInner); /** * Register 'where' clause.
* You can control the inner-join possibility. * @param clause The string clause of 'where'. (NotNull) * @param usedAliasInfos The array of information of used alias, contains no-way-inner determination. (NotNull, NotEmpty) */ void registerWhereClause(QueryClause clause, QueryUsedAliasInfo... usedAliasInfos); // ----------------------------------------------------- // WhereUsed Join // -------------- /** * Reflect the information of where-used-to join.
* Basically interface for DreamCruise. * @param usedAliasInfo The information of used alias, contains no-way-inner determination. (NotNull, NotEmpty) */ void reflectWhereUsedToJoin(QueryUsedAliasInfo usedAliasInfo); // ----------------------------------------------------- // Where Attribute // --------------- /** * Exchange first The clause of 'where' for last one. */ void exchangeFirstWhereClauseForLastOne(); /** * Does it have where clauses on the base query?
* Clauses on union queries and in-line views are not concerned. * @return The determination, true or false. */ boolean hasWhereClauseOnBaseQuery(); /** * Back up where clause on base query.
* You can restore it later. */ void backupWhereClauseOnBaseQuery(); /** * Restore where clause on base query if backup exists.
* You should call this after backup. */ void restoreWhereClauseOnBaseQuery(); /** * Clear where clauses on the base query.
* Clauses on union queries and in-line views are not concerned. */ void clearWhereClauseOnBaseQuery(); // =================================================================================== // In-line Where // ============= // ----------------------------------------------------- // In-line for Base Table // ---------------------- void registerBaseTableInlineWhereClause(ColumnSqlName columnSqlName, ConditionKey key, ConditionValue value, ColumnFunctionCipher cipher, ConditionOption option); void registerBaseTableInlineWhereClause(String value); boolean hasBaseTableInlineWhereClause(); void clearBaseTableInlineWhereClause(); // ----------------------------------------------------- // In-line for Outer Join // ---------------------- void registerOuterJoinInlineWhereClause(String foreignAliasName, ColumnSqlName columnSqlName, ConditionKey key, ConditionValue value, ColumnFunctionCipher cipher, ConditionOption option, boolean onClause); void registerOuterJoinInlineWhereClause(String foreignAliasName, String clause, boolean onClause); boolean hasOuterJoinInlineWhereClause(); void clearOuterJoinInlineWhereClause(); // =================================================================================== // OrScopeQuery // ============ /** * Begin or-scope query. */ void beginOrScopeQuery(); /** * End or-scope query. */ void endOrScopeQuery(); /** * Begin or-scope query to and-part. */ void beginOrScopeQueryAndPart(); /** * End or-scope query to and-part. */ void endOrScopeQueryAndPart(); /** * Is or-scope query effective? * @return The determination, true or false. */ boolean isOrScopeQueryEffective(); /** * Is and-part of or-scope effective? * @return The determination, true or false. */ boolean isOrScopeQueryAndPartEffective(); // =================================================================================== // OrderBy // ======= /** * @return The object of order-by clause. (NotNull) */ OrderByClause getOrderByComponent(); /** * Get the last element of order-by. * @return The order-by element object. (NullAllowed: when no order-by) */ OrderByElement getOrderByLastElement(); /** * Clear order-by information in this clause. */ void clearOrderBy(); /** * Suppress order-by temporarily. */ void suppressOrderBy(); /** * Revive order-by from suppressed status.
* You can call when not suppressed, only reloaded. */ void reviveOrderBy(); /** * @param orderByProperty Order-by-property. 'aliasName.columnSqlName/aliasName.columnSqlName/...' (NotNull) * @param ascOrDesc Is it ascend or descend? * @param columnInfo The information of the column for the order. (NotNull) */ void registerOrderBy(String orderByProperty, boolean ascOrDesc, ColumnInfo columnInfo); /** * @param orderByProperty Order-by-property. 'aliasName.columnSqlName/aliasName.columnSqlName/...' (NotNull) * @param ascOrDesc Is it ascend or descend? */ void registerSpecifiedDerivedOrderBy(String orderByProperty, boolean ascOrDesc); void addNullsFirstToPreviousOrderBy(); void addNullsLastToPreviousOrderBy(); void addManualOrderToPreviousOrderByElement(ManualOrderOption manualOrderOption); /** * Does it have order-by clauses?
* Whether effective or not has no influence. * @return The determination, true or false. */ boolean hasOrderByClause(); /** * Does it have order-by clauses as specified-derived order-by?
* Whether effective or not has no influence. * @return The determination, true or false. */ boolean hasSpecifiedDerivedOrderByClause(); // =================================================================================== // Union // ===== void registerUnionQuery(UnionClauseProvider unionClauseProvider, boolean unionAll); boolean hasUnionQuery(); void clearUnionQuery(); // =================================================================================== // FetchScope // ========== /** * Fetch first several rows only. * @param fetchSize The size of fetching. (NotMinus) */ void fetchFirst(int fetchSize); /** * Fetch scope (skip first several rows, and fetch first rows). * @param fetchStartIndex The index of fetch-start. 0 origin. (NotMinus) * @param fetchSize The size of fetching from start index. (NotMinus) */ void fetchScope(int fetchStartIndex, int fetchSize); /** * Fetch page. *

* When you invoke this, it is normally necessary to invoke 'fetchFirst()' or 'fetchScope()' ahead of that. * But you also can use default-fetch-size without invoking 'fetchFirst()' or 'fetchScope()'. * If you invoke this, your SQL returns [fetch-size] records from [fetch-start-index] calculated by [fetch-page-number]. *

* @param fetchPageNumber The number of fetch page. 1 origin. (NotMinus, NotZero: if minus or zero, set one) */ void fetchPage(int fetchPageNumber); /** * Get fetch start index. * @return Fetch start index. */ int getFetchStartIndex(); /** * Get fetch size. * @return Fetch size. */ int getFetchSize(); /** * Get fetch page number. * @return Fetch page number. */ int getFetchPageNumber(); /** * Get page start index. * @return Page start index. 0 origin. (NotMinus) */ int getPageStartIndex(); /** * Get page end index. * @return Page end index. 0 origin. (NotMinus) */ int getPageEndIndex(); /** * Suppress fetch-scope. */ void suppressFetchScope(); /** * Revive fetch-scope from suppressed status.
* You can call when not suppressed, only reloaded. */ void reviveFetchScope(); /** * Is fetch scope effective? * @return The determination, true or false. */ boolean isFetchScopeEffective(); /** * Is fetch start index supported? * @return The determination, true or false. */ boolean isFetchStartIndexSupported(); /** * Is fetch size supported? * @return The determination, true or false. */ boolean isFetchSizeSupported(); // =================================================================================== // Fetch Narrowing // =============== /** * Is fetch-narrowing effective? * @return Determiantion. */ boolean isFetchNarrowingEffective(); /** * Get fetch-narrowing skip-start-index. * @return Skip-start-index. */ int getFetchNarrowingSkipStartIndex(); /** * Get fetch-narrowing loop-count. * @return Loop-count. */ int getFetchNarrowingLoopCount(); // =================================================================================== // Lock // ==== /** * Lock selected records for update. *

* If you invoke this, your SQL lock target records for update. * It depends whether this method supports this on the database type. *

*/ void lockForUpdate(); // =================================================================================== // Table Alias Info // ================ /** * Get the alias name for base point table.
* @return The string name for alias. (NotNull) */ String getBasePointAliasName(); /** * Resolve alias name for join table. * @param relationPath The path of relation. e.g. _1_3 (NotNull) * @param nestLevel The nest level of condition query. * @return The resolved name. (NotNull) */ String resolveJoinAliasName(String relationPath, int nestLevel); /** * Resolve relation no. * @param localTableName The name of local table. (NotNull) * @param foreignPropertyName The property name of foreign relation. (NotNull) * @return The resolved relation No. */ int resolveRelationNo(String localTableName, String foreignPropertyName); /** * Get the alias name for base point table on in-line view. * @return The string name for alias. (NotNull) */ String getInlineViewBasePointAlias(); /** * Get the alias name for in-line view of union-query. * @return The string name for alias. (NotNull) */ String getUnionQueryInlineViewAlias(); /** * Get the alias name for derived column of nested DerivedReferrer. * @return The string name for alias. (NotNull) */ String getDerivedReferrerNestedAlias(); /** * Get the alias name for specified column of scalar-select. * @return The string name for alias. (NotNull) */ String getScalarSelectColumnAlias(); // =================================================================================== // Template Mark // ============= String getWhereClauseMark(); String getWhereFirstConditionMark(); String getUnionSelectClauseMark(); String getUnionWhereClauseMark(); String getUnionWhereFirstConditionMark(); // =================================================================================== // Where Clause Simple Filter // ========================== void addWhereClauseSimpleFilter(QueryClauseFilter whereClauseSimpleFilter); // =================================================================================== // Sub Query Indent // ================ String resolveSubQueryBeginMark(String subQueryIdentity); String resolveSubQueryEndMark(String subQueryIdentity); String processSubQueryIndent(String sql); // [DBFlute-0.7.4] // =================================================================================== // Specification // ============= // ----------------------------------------------------- // Specify Column // -------------- /** * Specify select columns.
* It is overridden when the specified column has already been specified. * @param specifiedColumn The info about column specification. (NotNull) */ void specifySelectColumn(SpecifiedColumn specifiedColumn); /** * Does it have specified select columns? * @param tableAliasName The alias name of table. (NotNull) * @return The determination, true or false. */ boolean hasSpecifiedSelectColumn(String tableAliasName); /** * Does it have the specified select column? * @param tableAliasName The alias name of table. (NotNull) * @param columnDbName The DB name of column. (NotNull) * @return The determination, true or false. */ boolean hasSpecifiedSelectColumn(String tableAliasName, String columnDbName); /** * Handle the specified select column in the table. * @param tableAliasName The alias name of table. (NotNull) * @param columnHandler The handler of the specified column. (NotNull) */ void handleSpecifiedSelectColumn(String tableAliasName, SpecifiedSelectColumnHandler columnHandler); /** * Back up specified select columns.
* You can restore it later. */ void backupSpecifiedSelectColumn(); /** * Restore specified select columns if backup exists.
* You should call this after backup. */ void restoreSpecifiedSelectColumn(); /** * Clear specified select columns. */ void clearSpecifiedSelectColumn(); // ----------------------------------------------------- // Specified as One // ---------------- /** * Get the only one specified column. * @return The instance as specified column. (NullAllowed: if not found or duplicated, returns null) */ SpecifiedColumn getSpecifiedColumnAsOne(); /** * Get the DB name of only one specified column. * @return The instance as string. (NullAllowed: if not found or duplicated, returns null) */ String getSpecifiedColumnDbNameAsOne(); /** * Get the information of only one specified column. * @return The instance as type for information of column. (NullAllowed: if not found or duplicated, returns null) */ ColumnInfo getSpecifiedColumnInfoAsOne(); /** * Get the real name of only one specified column. * @return The instance as type for real name of column. (NullAllowed: if not found or duplicated, returns null) */ ColumnRealName getSpecifiedColumnRealNameAsOne(); /** * Get the SQL name of only one specified column. * @return The instance as type for SQL name of column. (NullAllowed: if not found or duplicated, returns null) */ ColumnSqlName getSpecifiedColumnSqlNameAsOne(); // ----------------------------------------------------- // Specify Deriving // ---------------- /** * Specify deriving sub-query for DerivedReferrer.
* It is overridden when the specified column has already been specified.
* The aliasName is allowed to be null for (Specify)DerivedReferrer to be used in other functions. * @param subQueryInfo The info about deriving sub-query. (NotNull: aliasName is allowed to be null) */ void specifyDerivingSubQuery(HpDerivingSubQueryInfo subQueryInfo); /** * Does it have the specified deriving sub-query at least one? * @return the determination, true or false. */ boolean hasSpecifiedDerivingSubQuery(); /** * Does it have the specified deriving sub-query by the alias name? * @param aliasName The alias name of specified deriving sub-query. (NotNull) * @return the determination, true or false. */ boolean hasSpecifiedDerivingSubQuery(String aliasName); /** * Get the list of alias for specified deriving sub-query. * @return The list of alias. (NotNull: if no deriving, empty list) */ List getSpecifiedDerivingAliasList(); /** * Get the info of specified deriving sub-query by the alias name. * @param aliasName The alias name of specified deriving sub-query. (NotNull) * @return The info of specified deriving sub-query. (NullAlowed: if not found) */ HpDerivingSubQueryInfo getSpecifiedDerivingInfo(String aliasName); /** * Get the info of column for specified deriving sub-query by the alias name. * @param aliasName The alias name of specified deriving sub-query. (NotNull) * @return The info of column. (NullAlowed: if not found) */ ColumnInfo getSpecifiedDerivingColumnInfo(String aliasName); /** * Clear specified deriving sub-query. */ void clearSpecifiedDerivingSubQuery(); // ----------------------------------------------------- // Deriving as One // --------------- /** * Get the specified column for specified deriving sub-query as specified one. * @return The instance as specified column. (NullAlowed: if not found or not one) */ SpecifiedColumn getSpecifiedDerivingColumnAsOne(); /** * Get the info of column for specified deriving sub-query as specified one. * @return The instance as column info. (NullAlowed: if not found or not one) */ ColumnInfo getSpecifiedDerivingColumnInfoAsOne(); /** * Get the alias name for specified deriving sub-query as specified one. * @return The string for the alias name. (NullAlowed: if not found or not one) */ String getSpecifiedDerivingAliasNameAsOne(); /** * Get the clause of specified deriving sub-query as specified one. * @return The string for the clause. (NullAlowed: if not found or not one) */ String getSpecifiedDerivingSubQueryAsOne(); // ----------------------------------------------------- // Resolved as One // --------------- /** * Get the SQL name of definition resolved column (specified or deriving) as specified one. * @return The object of SQL name. (NullAllowed: if not found or not one) */ ColumnSqlName getSpecifiedResolvedColumnSqlNameAsOne(); /** * Get the real name of sub-query resolved column (specified or deriving) as specified one.
* And the SpecifyCalculation is resolved here. * @return The object of real name. (NullAllowed: if not found or not one) */ ColumnRealName getSpecifiedResolvedColumnRealNameAsOne(); // =================================================================================== // Invalid Query Info // ================== // ----------------------------------------------------- // NullOrEmpty Query // ----------------- /** * Check null-or-empty query.
* The default is ignored, but public default is checked by DBFluteConfig */ void checkNullOrEmptyQuery(); /** * Ignore null-or-empty query. */ void ignoreNullOrEmptyQuery(); /** * Is null-or-empty query checked? * @return The determination, true or false. */ boolean isNullOrEmptyQueryChecked(); /** * Get the list of invalid query. (basically for logging) * @return The list of invalid query. (NotNull, ReadOnly) */ List getInvalidQueryList(); /** * Save the invalid query. * @param invalidQueryInfo The information of invalid query. (NotNull) */ void saveInvalidQuery(HpInvalidQueryInfo invalidQueryInfo); // ----------------------------------------------------- // Empty String // ------------ /** * Enable empty string query (means allowed). (default is disabled, means checked) */ void enableEmptyStringQuery(); /** * Disable empty string query. (back to default) */ void disableEmptyStringQuery(); /** * Is empty string allowed? * @return The determination, true or false. */ boolean isEmptyStringQueryAllowed(); // ----------------------------------------------------- // Overriding Query // ---------------- /** * Enable overriding query (means allowed). (default is disabled, means checked) */ void enableOverridingQuery(); /** * Disable overriding query. (back to default) */ void disableOverridingQuery(); /** * Is overriding query allowed? * @return The determination, true or false. */ boolean isOverridingQueryAllowed(); // [DBFlute-0.8.6] // =================================================================================== // Select Clause Type // ================== /** * Classify the type of select clause into specified type. * @param selectClauseType The type of select clause. (NotNull) */ void classifySelectClauseType(SelectClauseType selectClauseType); /** * Roll-back the type of select clause into previous one. * If it has no change, classify its type into default type. */ void rollbackSelectClauseType(); // [DBFlute-0.9.8.6] // =================================================================================== // ColumnQuery Object // ================== /** * Get the map for ColumnQuery objects for parameter comment. {Internal} * @return The map for ColumnQuery objects. (NullAllowed: if null, means no object) */ Map getColumnQueryObjectMap(); /** * Register ColumnQuery object to theme list. {Internal} * @param themeKey The key for the object. (NotNull) * @param addedValue The value added to theme list for the object. (NotNull) * @return The expression for binding. (NotNull) */ String registerColumnQueryObjectToThemeList(String themeKey, Object addedValue); // [DBFlute-0.9.8.6] // =================================================================================== // ManualOrder Parameter // ===================== /** * Get the map for ManualOrder parameters for parameter comment. {Internal} * @return The map for ManualOrder parameters. (NullAllowed: if null, means no parameter) */ Map getManualOrderParameterMap(); /** * Register ManualOrder parameter to theme list. {Internal} * @param themeKey The theme as key for the parameter. (NotNull) * @param addedValue The value added to theme list for the parameter. (NullAllowed) * @return The expression for binding. (NotNull) */ String registerManualOrderParameterToThemeList(String themeKey, Object addedValue); // [DBFlute-0.9.8.2] // =================================================================================== // Free Parameter // ============== /** * Get the map for free parameters for parameter comment. {Internal} * @return The map for free parameters. (NullAllowed: if null, means no parameter) */ Map getFreeParameterMap(); /** * Register free parameter to theme list. {Internal} * @param themeKey The theme as key for the parameter. (NotNull) * @param addedValue The value added to theme list for the parameter. (NullAllowed) * @return The expression for binding. (NotNull) */ String registerFreeParameterToThemeList(String themeKey, Object addedValue); // [DBFlute-0.9.8.4] // =================================================================================== // Geared Cipher // ============= /** * Get the manager of geared cipher. * @return The instance of manager. (NullAllowed: when no geared cipher) */ GearedCipherManager getGearedCipherManager(); /** * Find the cipher for the column. * @param columnInfo The column info for cipher. (NotNull) * @return The cipher for the column. (NullAllowed: when no geared cipher or the column is not cipher target) */ ColumnFunctionCipher findColumnFunctionCipher(ColumnInfo columnInfo); /** * Enable select column cipher effective.
* The default is enabled (if cipher manager is set) so this method is called after disabling. */ void enableSelectColumnCipher(); /** * Disable select column cipher effective.
* basically for queryInsert(). */ void disableSelectColumnCipher(); // [DBFlute-0.9.8.4] // =================================================================================== // ScalarSelect Option // =================== /** * Accept the option of scalar-select. * @param option The instance of option object. (NullAllowed: if null, also clear existing option) */ void acceptScalarSelectOption(ScalarSelectOption option); // [DBFlute-0.9.8.8] // =================================================================================== // Paging Select // ============= // ----------------------------------------------------- // Paging Adjustment // ----------------- /** * Enable paging adjustment, e.g. PagingCountLater, PagingCountLeastJoin, effective.
* The options might be on by default so the adjustments are off normally. */ void enablePagingAdjustment(); /** * Disable paging adjustment. */ void disablePagingAdjustment(); // ----------------------------------------------------- // Count Later // ----------- /** * Enable paging count-later that means counting after selecting.
* And you should also make paging adjustment effective to enable this.
* This option is copy of condition-bean's one for clause adjustment, e.g. MySQL found_rows().
* The default is disabled, but public default is enabled by DBFluteConfig. */ void enablePagingCountLater(); /** * Disable paging count-later that means counting after selecting.
* You should call this before execution of selectPage(). */ void disablePagingCountLater(); // ----------------------------------------------------- // Count LeastJoin // --------------- /** * Enable paging count-least-join, which means least joined on count select.
* And you should also make paging adjustment effective to enable this.
* The default is disabled, but public default is enabled by DBFluteConfig. */ void enablePagingCountLeastJoin(); /** * Disable paging count-least-join, which means least joined on count select.
* You should call this before execution of selectPage(). */ void disablePagingCountLeastJoin(); /** * Can it be paging count least join? * @return The determination, true or false. */ boolean canPagingCountLeastJoin(); // [DBFlute-1.0.5G] // ----------------------------------------------------- // PK Only Select // -------------- /** * Enable PK only select forcedly effective, ignoring select clause setting and derived referrer.
* Basically for PagingSelectAndQuerySplit. */ void enablePKOnlySelectForcedly(); /** * Disable PK only select forcedly.
* Basically for PagingSelectAndQuerySplit. */ void disablePKOnlySelectForcedly(); // [DBFlute-0.9.9.4C] // =================================================================================== // Lazy Reflector // ============== /** * Register the lazy reflector of clause. * @param clauseLazyReflector The instance of reflector. (NotNull) */ void registerClauseLazyReflector(ClauseLazyReflector clauseLazyReflector); // [DBFlute-0.7.5] // =================================================================================== // Query Update // ============ /** * @param fixedValueQueryExpMap The map of query expression for fixed values. (NotNull) * @param resourceSqlClause The SQL clause for resource. (NotNull) * @return The clause of query-insert. (NotNull) */ String getClauseQueryInsert(Map fixedValueQueryExpMap, SqlClause resourceSqlClause); /** * @param columnParameterMap The map of column parameters. The parameter may be handler. (NotNull) * @return The clause of query-update. (NullAllowed: If columnParameterMap is empty, return null) */ String getClauseQueryUpdate(Map columnParameterMap); /** * The handler of calculation on set clause of query-update.
* This is set on column parameter map as value. */ interface QueryUpdateSetCalculationHandler { /** * @param aliasName The alias name of calculation column. (NullAllowed) * @return The statement string. (NotNull) */ String buildStatement(String aliasName); } /** * @return The clause of query-delete. (NotNull) */ String getClauseQueryDelete(); /** * Enable to use direct clause in query update forcedly (contains query delete). * You cannot use join, sub-query, union and so on, by calling this.
* So you may have the painful SQLException by this, attention! */ void enableQueryUpdateForcedDirect(); // [DBFlute-0.9.7.2] // =================================================================================== // Purpose Type // ============ /** * Get the purpose of the condition-bean. e.g. NORMAL_USE, EXISTS_REFERRER * @return The instance of purpose object for condition-bean. (NotNull) */ HpCBPurpose getPurpose(); /** * Set the purpose of the condition-bean. e.g. NORMAL_USE, EXISTS_REFERRER * @param purpose The instance of purpose object for condition-bean. (NotNull) */ void setPurpose(HpCBPurpose purpose); /** * Is the clause object locked? e.g. true if in sub-query process and check allowed
* Java8 cannot use the same name as lambda argument with already existing name in the scope. *
     * cb.query().existsPurchaseList(subCB -> {
     *     subCB.query().existsPurchaseDetailList(subCB -> { // *NG
     *     });
     * });
     * 
*

You should rename it, however the other condition-bean might be called. * So it is necessary to check it, and condition-bean has lock.

* *

While, you can suppress it by option for compatible. (if suppressed, always returns false)

* * @return The determination, true or false. */ boolean isLocked(); /** * Lock the clause object.
* Only saving lock status here, you should rightly check by this status. */ void lock(); /** * Unlock the clause object. */ void unlock(); /** * Enable "that's-bad-timing" detect. */ void enableThatsBadTimingDetect(); /** * Disable "that's-bad-timing" detect for compatible.
* If disabled, isLocked() always returns false. */ void disableThatsBadTimingDetect(); /** * Does it allow "that's-bad-timing" detect? * @return The determination, true or false. */ boolean isThatsBadTimingDetectAllowed(); // [DBFlute-0.9.4] // =================================================================================== // InScope Limit // ============= /** * Get the limit of inScope. * @return The limit of inScope. (If it's zero or minus, it means no limit) */ int getInScopeLimit(); // [DBFlute-0.9.8.4] // =================================================================================== // LikeSearch Adjustment // ===================== /** * Adjust like-search of DB way. * @param option The option of like-search to adjust. (NotNull) */ void adjustLikeSearchDBWay(LikeSearchOption option); // [DBFlute-1.0.3.1] // =================================================================================== // CursorSelect Option // =================== /** * Is cursor select by paging allowed? * @return The determination, true or false. */ boolean isCursorSelectByPagingAllowed(); // [DBFlute-1.1.0] // =================================================================================== // ExistsReferrer Way // ================== /** * Use in-scope sub-query for exists-referrer. (save-only attribute) */ void useInScopeSubQueryForExistsReferrer(); /** * Does it use in-scope sub-query for exists-referrer? * @return The determination, true or false. */ boolean isUseInScopeSubQueryForExistsReferrer(); // =================================================================================== // Column NullObject // ================= /** * Enable the handling of column null object. (default is disabled) */ void enableColumnNullObject(); // called by condition-bean /** * Disable the handling of column null object. (back to default) */ void disableColumnNullObject(); // called by condition-bean /** * Is the handling of column null object enabled? * @return The determination, true or false. */ boolean isColumnNullObjectAllowed(); // called by result set handler /** * Enable the handling of column null object geared to specify. (default is disabled, means checked) */ void enableColumnNullObjectGearedToSpecify(); // called by SQL-clause creator /** * Disable the handling of column null object geared to specify. (back to default) */ void disableColumnNullObjectGearedToSpecify(); // called by SQL-clause creator /** * Get the set of column specified as null object for the local table.
* Basically for synchronization with non-specified access check. * @return The set of column info. (NotNull, EmptyAllowed) */ Set getLocalSpecifiedNullObjectColumnSet(); // called by row creator /** * Get the set of column specified as null object for the relation.
* Basically for synchronization with non-specified access check. * @param relationNoSuffix The suffix of relation No, same as foreign relation path. (NotNull) * @return The set of column info. (NotNull, EmptyAllowed) */ Set getRelationSpecifiedNullObjectColumnSet(String relationNoSuffix); // called by relation row creator // [DBFlute-0.9.8.4] // =================================================================================== // DBWay // ===== /** * Get the DB way for this SQL clause. * @return The instance of DB way. (NotNull) */ DBWay dbway(); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy