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

org.dbflute.bhv.BehaviorReadable Maven / Gradle / Ivy

/*
 * Copyright 2014-2020 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.bhv;

import org.dbflute.Entity;
import org.dbflute.bhv.readable.EntityRowHandler;
import org.dbflute.cbean.ConditionBean;
import org.dbflute.cbean.chelper.HpSLSFunction;
import org.dbflute.cbean.result.ListResultBean;
import org.dbflute.cbean.result.PagingResultBean;
import org.dbflute.dbmeta.DBMeta;
import org.dbflute.outsidesql.executor.OutsideSqlAllFacadeExecutor;

/**
 * The interface of behavior-readable.
 * @author jflute
 */
public interface BehaviorReadable {

    // ===================================================================================
    //                                                                             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();

    // ===================================================================================
    //                                                                        New Instance
    //                                                                        ============
    /**
     * New entity instance.
     * @return Entity. (NotNull)
     */
    Entity newEntity();

    /**
     * New condition-bean instance.
     * @return Condition-bean. (NotNull)
     */
    ConditionBean newConditionBean();

    // ===================================================================================
    //                                                                    Basic Read Count
    //                                                                    ================
    /**
     * Read count by condition-bean. 
* An interface dispatch for selectCount(). * @param cb The instance of corresponding condition-bean. (NotNull) * @return Read count. (NotNull) */ int readCount(ConditionBean cb); // =================================================================================== // Basic Read Entity // ================= /** * Read entity by condition-bean.
* An interface dispatch for selectEntity(). * @param cb The instance of corresponding condition-bean. (NotNull) * @return Read entity. (NullAllowed: when not found) */ Entity readEntity(ConditionBean cb); /** * Read simple entity by condition-bean with deleted check.
* An interface dispatch for selectEntityWithDeletedCheck(). * @param cb The instance of corresponding condition-bean. (NotNull) * @return Read entity. (NotNull) */ Entity readEntityWithDeletedCheck(ConditionBean cb); // =================================================================================== // Basic Read List // =============== /** * Read list as result-bean.
* An interface dispatch for selectList(). * @param The result type of entity. * @param cb The instance of corresponding condition-bean. (NotNull) * @return The list of entity as result-bean. If the select result is zero, it returns empty list. (NotNull) */ ListResultBean readList(ConditionBean cb); /** * Read page as result-bean.
* An interface dispatch for selectPage(). * @param The result type of entity. * @param cb The instance of corresponding condition-bean. (NotNull) * @return The page of entity as result-bean. (NotNull) */ PagingResultBean readPage(ConditionBean cb); // =================================================================================== // Cursor Read // =========== /** * Read the cursor by the row handler.
* An interface dispatch for selecrCursor(). * @param The result type of entity. * @param cb The instance of corresponding condition-bean. (NotNull) * @param entityLambda The handler of entity row. (NotNull) */ void readCursor(ConditionBean cb, EntityRowHandler entityLambda); // =================================================================================== // Scalar Read // =========== /** * Read the scalar value derived by a function from uniquely-selected records.
* An interface dispatch for selectScalar(). * @param The type of scalar result. * @param resultType The type of result. (NotNull) * @return The scalar function object to specify function for scalar value. (NotNull) */ HpSLSFunction readScalar(Class resultType); // =================================================================================== // Sequence // ======== /** * Read next value of sequence.
* An interface dispatch for selectNextVal(). * @return The next value of sequence. (NotNull) */ Number readNextVal(); // =================================================================================== // OutsideSql // ========== /** * Prepare an outside-SQL execution by returning an instance of the executor for outside-SQL. * @param The type of behavior. * @return The facade for outside-SQL. (NotNull) */ OutsideSqlAllFacadeExecutor readyOutsideSql(); // =================================================================================== // Warm Up // ======= /** * Warm up the command of behavior. {Internal} */ void warmUpCommand(); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy