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

org.dbflute.cbean.ConditionBean Maven / Gradle / Ivy

/*
 * Copyright 2014-2015 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;

import java.util.Map;

import org.dbflute.cbean.chelper.HpCBPurpose;
import org.dbflute.cbean.chelper.HpColumnSpHandler;
import org.dbflute.cbean.coption.CursorSelectOption;
import org.dbflute.cbean.coption.ScalarSelectOption;
import org.dbflute.cbean.coption.StatementConfigCall;
import org.dbflute.cbean.dream.SpecifiedColumn;
import org.dbflute.cbean.dream.WelcomeToDreamCruise;
import org.dbflute.cbean.paging.PagingBean;
import org.dbflute.cbean.scoping.AndQuery;
import org.dbflute.cbean.scoping.ModeQuery;
import org.dbflute.cbean.scoping.OrQuery;
import org.dbflute.cbean.scoping.UnionQuery;
import org.dbflute.cbean.sqlclause.SqlClause;
import org.dbflute.dbmeta.DBMeta;
import org.dbflute.dbmeta.accessory.DerivedTypeHandler;
import org.dbflute.exception.ConditionInvokingFailureException;
import org.dbflute.jdbc.StatementConfig;
import org.dbflute.twowaysql.style.BoundDateDisplayStyle;

/**
 * The bean for condition.
 * @author jflute
 */
public interface ConditionBean extends PagingBean, WelcomeToDreamCruise {

    // ===================================================================================
    //                                                                             DB Meta
    //                                                                             =======
    /**
     * Handle the meta as DBMeta, that has all info of the table.
     * @return The (singleton) instance of DB meta for the table. (NotNull)
     */
    DBMeta asDBMeta();

    /**
     * Handle the meta as table DB name, that can be identity of table..
     * @return The (fixed) DB name of the table. (NotNull)
     */
    String asTableDbName();

    // ===================================================================================
    //                                                                           SqlClause
    //                                                                           =========
    /**
     * Get SQL clause instance. {Internal}
* @return The object for SQL clause. (NotNull) */ SqlClause getSqlClause(); // =================================================================================== // PrimaryKey Handling // =================== /** * Accept the map of primary-keys. map:{[column-name] = [value]} * @param primaryKeyMap The map of primary-keys. (NotNull and NotEmpty) */ void acceptPrimaryKeyMap(Map primaryKeyMap); /** * Add order-by PrimaryKey asc. {order by primaryKey1 asc, primaryKey2 asc...} * @return this. (NotNull) */ ConditionBean addOrderBy_PK_Asc(); /** * Add order-by PrimaryKey desc. {order by primaryKey1 desc, primaryKey2 desc...} * @return this. (NotNull) */ ConditionBean addOrderBy_PK_Desc(); // =================================================================================== // Specify // ======= /** * Get the handler of the column specification as interface. * @return The instance of column specification. (NotNull: instance is created if null) */ HpColumnSpHandler localSp(); /** * Does it have specified columns for the local table at least one?
* (without new-creation of specification instance) * @return The determination, true or false. */ boolean hasSpecifiedLocalColumn(); // make when it needs (for compile speed) ///** // * Does it have specified columns at least one? (without new-creation of specification instance) // * @return The determination, true or false. // */ //boolean hasSpecifiedRelationColumn(); /** * Does it have specified columns at least one? (without new-creation of specification instance) * @return The determination, true or false. * @deprecated use hasSpecifiedLocalColumn() */ boolean hasSpecifiedColumn(); // =================================================================================== // Query // ===== /** * Get the conditionQuery of the local table as interface. * @return The instance of conditionQuery. (NotNull: instance is created if null) */ ConditionQuery localCQ(); /** * Enable to auto-detect joins that can be inner-join. (back to default)
*
     * o You should call this before registrations of where clause.
     * o Union and SubQuery and other sub condition-bean inherit this.
     * o You should confirm your SQL on the log to be tuned by inner-join correctly.
     * 
*/ void enableInnerJoinAutoDetect(); /** * Disable auto-detecting inner-join. (default is enabled)
* You should call this before registrations of where clause. */ void disableInnerJoinAutoDetect(); // =================================================================================== // Dream Cruise // ============ /** * Invite the derived column to dream cruise. (returns the ticket) * @param derivedAlias The alias name for derived column. (NotNull) * @return The ticket column specified by your Dream Cruise. (NotNull) */ SpecifiedColumn inviteDerivedToDreamCruise(String derivedAlias); // user interface /** * Create condition-bean for dream cruise. * @return The created condition-bean for Dream Cruise. (NotNull) */ ConditionBean xcreateDreamCruiseCB(); /** * Mark as departure port for dream cruise. */ void xmarkAsDeparturePortForDreamCruise(); /** * Is this condition-bean departure port for dream cruise? * @return The determination, true or false. */ boolean xisDreamCruiseDeparturePort(); /** * Is this condition-bean for dream cruise? * @return The determination, true or false. */ boolean xisDreamCruiseShip(); /** * Get the departure port of dream cruise?
* (condition-bean creating the condition-bean) * @return The base condition-bean for Dream Cruise. (NullAllowed: when not dream cruise) */ ConditionBean xgetDreamCruiseDeparturePort(); /** * Do you have a Dream Cruise ticket?
* (whether this CB has the specified column by dream cruise or not) * @return The determination, true or false. */ boolean xhasDreamCruiseTicket(); /** * Show me your Dream Cruise ticket.
* (get the specified column by Dream Cruise) * @return The information of specified column. (NullAllowed) */ SpecifiedColumn xshowDreamCruiseTicket(); /** * Keep journey log-book of Dream Cruise.
* (save the relation trace by Dream Cruise) * @param relationPath The path of relation. (NotNull) */ void xkeepDreamCruiseJourneyLogBook(String relationPath); /** * Set up select for journey log-book of Dream Cruise. */ void xsetupSelectDreamCruiseJourneyLogBook(); /** * Set up select for journey log-book of Dream Cruise if union query exists. */ void xsetupSelectDreamCruiseJourneyLogBookIfUnionExists(); /** * Get the value of mystic binding. * @return The object value for mystic binding. (NullAllowed: if null, no mystic) */ Object xgetMysticBinding(); // =================================================================================== // Invalid Query // ============= /** * Ignore null-or-empty check for query when query is set. (default is checked)
* (no condition if set query is invalid) *
     * memberBhv.selectList(cb -> {
     *     cb.ignoreNullOrEmptyQuery();
     *     cb.query().setMemberName_Equal(null); // no condition (ignored)
     *     cb.query().setMemberName_Equal("");   // no condition (ignored)
     *     cb.query().setMemberName_Equal(" ");  // valid (MEMBER_NAME = ' ')
     * });
     * 
* You should call this before registrations of where clause and other queries.
* And Union and SubQuery and other sub condition-bean inherit this. */ void ignoreNullOrEmptyQuery(); // no mode-query because of high use and wide scope /** * Check null or empty value for query when query is set. (back to default)
* (it throws exception if set query is invalid, e.g. null, empty string, empty list)
* You should call this before registrations of where clause and other queries.
* Union and SubQuery and other sub condition-bean inherit this. */ void checkNullOrEmptyQuery(); /** * Enable empty string for query. (default is disabled)
* (you can use an empty string as condition)
* You should call this before registrations of where clause and other queries.
* Union and SubQuery and other sub condition-bean inherit this. * @param noArgInLambda The callback for empty-string query. (NotNull) */ void enableEmptyStringQuery(ModeQuery noArgInLambda); /** * Disable empty string for query. (back to default)
* The empty string for query is treated as invalid data, like null. */ void disableEmptyStringQuery(); /** * Enable overriding query. (default is disabled)
* (you can override existing value as condition)
* You should call this before registrations of where clause and other queries.
* Union and SubQuery and other sub condition-bean inherit this. * @param noArgInLambda The callback for overriding query. (NotNull) */ void enableOverridingQuery(ModeQuery noArgInLambda); /** * Disable overriding query. (back to default)
* You should set query to same column and same condition once. */ void disableOverridingQuery(); // =================================================================================== // Paging Setting // ============== /** * Enable paging count-least-join, which means least joined on count select. (back to default)
* You can use it by default on DBFlute so you don't need to call this basically. * If you've suppressed it by settings of DBFlute property, you can use it by calling.
* You should call this before execution of selectPage(). */ void enablePagingCountLeastJoin(); /** * Disable paging count-least-join, which means least joined on count select. (default is enabled)
* You should call this before execution of selectPage(). */ void disablePagingCountLeastJoin(); /** * Can the SQL execution be split by select and query? * @return The determination, true or false. */ boolean canPagingSelectAndQuerySplit(); // =================================================================================== // Lock Setting // ============ /** * Lock for update.
* If you call this, your SQL lock target records for update.
* It depends whether this method supports this on the database type. * @return this. (NotNull) */ ConditionBean lockForUpdate(); // =================================================================================== // Select Count // ============ /** * Set up various things for select-count-ignore-fetch-scope. {Internal} * This method is for INTERNAL. Don't call this! * @param uniqueCount Is it unique-count select? * @return this. (NotNull) */ ConditionBean xsetupSelectCountIgnoreFetchScope(boolean uniqueCount); /** * Do after-care for select-count-ignore-fetch-scope. {Internal} * This method is for INTERNAL. Don't call this! * @return this. (NotNull) */ ConditionBean xafterCareSelectCountIgnoreFetchScope(); /** * Is set up various things for select-count-ignore-fetch-scope? {Internal} * This method is for INTERNAL. Don't call this! * @return The determination, true or false. */ boolean isSelectCountIgnoreFetchScope(); // =================================================================================== // Cursor Select // ============= /** * Get the option of cursor select. * @return The option of cursor select. (NullAllowed: when no option) */ CursorSelectOption getCursorSelectOption(); // the customizeCursorSelect() method is generated at sub-class // because the method is generated only when allowed DBMS // =================================================================================== // Scalar Select // ============= /** * Accept the option for ScalarSelect. * @param option The option for ScalarSelect. (NullAllowed) */ void xacceptScalarSelectOption(ScalarSelectOption option); // =================================================================================== // Statement Configuration // ======================= /** * Configure statement JDBC options. e.g. queryTimeout, fetchSize, ... (only one-time call) *
     * cb.configure(conf -> conf.queryTimeout(3));
     * 
* @param confLambda The callback for configuration of statement. (NotNull) */ void configure(StatementConfigCall confLambda); /** * Get the configuration of statement that is set through configure(). * @return The configuration of statement. (NullAllowed) */ StatementConfig getStatementConfig(); // =================================================================================== // Entity Mapping // ============== // no need to use it as interface method so comment out ///** // * Disable (entity instance) cache of relation mapping.
// * Basically you don't need this. This is for accidents. // */ //void disableRelationMappingCache(); /** * Can the relation mapping (entity instance) be cached? * @return The determination, true or false. */ boolean canRelationMappingCache(); /** * Enable access to non-specified column. (default is disabled)
* You can get columns of base-point or setup-select using SpecifyColumn but non-specified column. *
     * memberBhv.selectEntity(cb -> {
     *     cb.setupSelect_MemberStatus();
     *     cb.specify().columnMemberStatusName();
     *     cb.query().set...
     * }).alwaysPresent(member -> {
     *     member.getMemberStatus().alwaysPresent(status -> {
     *         ... = status.getMemberStatusName(); // OK
     *         ... = status.getDisplayOrder(); // OK: allowed
     *     });
     * });
     * 
*/ void enableNonSpecifiedColumnAccess(); /** * Disable the check of access to non-specified column. (back to default)
* You cannot get columns of base-point or setup-select using SpecifyColumn but non-specified column. *
     * memberBhv.selectEntity(cb -> {
     *     cb.setupSelect_MemberStatus();
     *     cb.specify().columnMemberStatusName();
     *     cb.query().set...
     * }).alwaysPresent(member -> {
     *     member.getMemberStatus().alwaysPresent(status -> {
     *         ... = status.getMemberStatusName(); // OK
     *         ... = status.getDisplayOrder(); // *NG: exception
     *     });
     * });
     * 
*/ void disableNonSpecifiedColumnAccess(); /** * Is the access to non-specified column allowed? * @return The determination, true or false. */ boolean isNonSpecifiedColumnAccessAllowed(); // =================================================================================== // Undefined Classification // ======================== /** * Enable the select of undefined classification code. (default is disabled) * You can get undefined classification code from database. */ void enableUndefinedClassificationSelect(); /** * Disable the select of undefined classification code. (back to default) */ void disableUndefinedClassificationSelect(); /** * Is the selecting undefined classification code allowed? * @return The determination, true or false. */ boolean isUndefinedClassificationSelectAllowed(); // =================================================================================== // Column NullObject // ================= /** * Enable the handling of column null object. (default is disabled)
* The handling is available if the null object target column in selected entity. */ void enableColumnNullObject(); /** * Disable the handling of column null object. (back to default)
* You can get null from selected entity even if null object target column. */ void disableColumnNullObject(); // =================================================================================== // Query Update // ============ /** * Enable checking record count before QueryUpdate (contains QueryDelete). (default is disabled)
* No query update if zero count. (basically for MySQL's deadlock by next-key lock) */ void enableQueryUpdateCountPreCheck(); /** * Disable checking record count before QueryUpdate (contains QueryDelete). (back to default)
* Executes query update even if zero count. (normal specification) */ void disableQueryUpdateCountPreCheck(); /** * Does it check record count before QueryUpdate (contains QueryDelete)? * @return The determination, true or false. */ boolean isQueryUpdateCountPreCheck(); // =================================================================================== // Display SQL // =========== /** * Convert this conditionBean to SQL for display. * @return SQL for display. (NotNull and NotEmpty) */ String toDisplaySql(); /** * Style bound dates on logging display SQL, overriding default style. * @param logDateDisplayStyle The display style of date for logging. (NullAllowed: if null, configured default style) */ void styleLogDateDisplay(BoundDateDisplayStyle logDateDisplayStyle); /** * Get the display style of date for logging. * @return The specified style object. (NullAllowed: if null, configured default style) */ BoundDateDisplayStyle getLogDateDisplayStyle(); // =================================================================================== // Meta Handling // ============= /** * Does it have where clause on the base query?
* Clauses on union queries and in-line views are not concerned. * @return The determination, true or false. */ boolean hasWhereClauseOnBaseQuery(); /** * Clear where clauses where clause on the base query.
* Clauses on union queries and in-line views are not concerned. */ void clearWhereClauseOnBaseQuery(); /** * Does it have select-all possible?
* The elements for possible are: *
     * o no where clause on base query
     * o no where clause in base table in-line view
     * o union queries with select-all possible
     * 
* @return The determination, true or false. */ boolean hasSelectAllPossible(); /** * Does it have order-by clauses?
* Whether that order-by is effective or not has no influence. * @return The determination, true or false. */ boolean hasOrderByClause(); // clearOrderBy() is defined at OrderByBean /** * Has union query or union all query? * @return The determination, true or false. */ boolean hasUnionQueryOrUnionAllQuery(); // =================================================================================== // Reflection Invoking // =================== /** * Invoke the method 'setupSelect_Xxx()' and 'withXxx()' by the path of foreign property name.
* For example, if this is based on PURCHASE, 'member.memberStatus' means as follows: *
     * PurchaseCB cb = new PurchaseCB();
     * cb.setupSelect_Member().withMemberStatus();
     * 
* A method with parameters (using fixed condition) is unsupported. * @param foreignPropertyNamePath The path string. (NotNull, NotTrimmedEmpty) * @throws ConditionInvokingFailureException When the method to the property is not found and the method is failed. */ void invokeSetupSelect(String foreignPropertyNamePath); /** * Invoke the method 'specify().columnXxx()' by the path of column name.
* For example, if this is based on PURCHASE, 'purchaseDatetime' means as follows: *
     * PurchaseCB cb = new PurchaseCB();
     * cb.specify().columnPurchaseDatetime();
     * 
* And if this is based on PURCHASE, 'member.memberName' means as follows: *
     * PurchaseCB cb = new PurchaseCB();
     * cb.specify().specifyMember().columnMemberName();
     * 
* @param columnPropertyPath The path string to property for the column. (NotNull, NotTrimmedEmpty) * @return The info of specified column. (NotNull) * @throws ConditionInvokingFailureException When the method to the property is not found and the method is failed. */ SpecifiedColumn invokeSpecifyColumn(String columnPropertyPath); /** * Invoke the method 'orScopeQuery()' by the query callback.
* @param orQuery The callback for or-query. (NotNull) * @throws ConditionInvokingFailureException When the method to the property is not found and the method is failed. */ void invokeOrScopeQuery(OrQuery orQuery); /** * Invoke the method 'orScopeQueryAndPart()' by the query callback.
* @param andQuery The callback for and-query. (NotNull) * @throws ConditionInvokingFailureException When the method to the property is not found and the method is failed. */ void invokeOrScopeQueryAndPart(AndQuery andQuery); // =================================================================================== // Query Synchronizer // ================== /** * Register union-query synchronizer. {Internal}
* Basically for reflecting LoadReferrer's InScope condition to union-queries in condition-bean set-upper. * @param unionQuerySynchronizer The synchronizer of union query. (NullAllowed) */ void xregisterUnionQuerySynchronizer(UnionQuery unionQuerySynchronizer); // =================================================================================== // Derived Mappable // ================ /** * Get the handler of derived type for derived mappable entity (for (Specify)DerivedReferrer).
* Called by internal mapping process, so should be fixed instance. * @return The handler of derived type. (NotNull) */ DerivedTypeHandler xgetDerivedTypeHandler(); // =================================================================================== // 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(); // ----------------------------------------------------- // Internal Setup // -------------- // only methods called by interface are defined /** * Set up condition-bean for ScalarSelect. */ void xsetupForScalarSelect(); /** * Set up condition-bean for QueryInsert. */ void xsetupForQueryInsert(); /** * Set up condition-bean for SpecifiedUpdate. */ void xsetupForSpecifiedUpdate(); /** * Set up condition-bean for VaryingUpdate. */ void xsetupForVaryingUpdate(); // ----------------------------------------------------- // Lock // ---- /** * Enable "that's bad timing" check. (back to default) */ void enableThatsBadTiming(); /** * Disable "that's bad timing" check. (default is enabled) */ void disableThatsBadTiming(); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy