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

org.dbflute.cbean.chelper.HpSSQFunction 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.chelper;

import org.dbflute.cbean.ConditionBean;
import org.dbflute.cbean.scoping.SubQuery;

/**
 * The function for ScalarCondition (the old name: ScalarSubQuery).
 * @param  The type of condition-bean.
 * @author jflute
 */
public class HpSSQFunction {

    // ===================================================================================
    //                                                                           Attribute
    //                                                                           =========
    protected final HpSSQSetupper _setupper;

    // ===================================================================================
    //                                                                         Constructor
    //                                                                         ===========
    public HpSSQFunction(HpSSQSetupper setupper) {
        _setupper = setupper;
    }

    // ===================================================================================
    //                                                                            Function
    //                                                                            ========
    /**
     * Set up the sub query of myself for the scalar 'max'.
     * 
     * cb.query().scalar_Equal().max(purchaseCB -> {
     *     public void query(PurchaseCB subCB) {
     *         purchaseCB.specify().columnPurchasePrice(); // *Point!
     *         purchaseCB.query().setPaymentCompleteFlg_Equal_True();
     *     }
     * });
     * 
* @param scalarCBLambda The callback for sub-query of myself. (NotNull) * @return The decorator of ScalarCondition. e.g. you can use partition-by. (NotNull) */ public HpSSQDecorator max(SubQuery scalarCBLambda) { assertSubQuery(scalarCBLambda); final HpSSQOption option = createOption(); _setupper.setup("max", scalarCBLambda, option); return createDecorator(option); } /** * Set up the sub query of myself for the scalar 'min'. *
     * cb.query().scalar_Equal().min(purchaseCB -> {
     *     public void query(PurchaseCB subCB) {
     *         purchaseCB.specify().columnPurchasePrice(); // *Point!
     *         purchaseCB.query().setPaymentCompleteFlg_Equal_True();
     *     }
     * });
     * 
* @param scalarCBLambda The callback for sub-query of myself. (NotNull) * @return The decorator of ScalarCondition. e.g. you can use partition-by. (NotNull) */ public HpSSQDecorator min(SubQuery scalarCBLambda) { assertSubQuery(scalarCBLambda); final HpSSQOption option = createOption(); _setupper.setup("min", scalarCBLambda, option); return createDecorator(option); } /** * Set up the sub query of myself for the scalar 'sum'. *
     * cb.query().scalar_Equal().sum(purchaseCB -> {
     *     purchaseCB.specify().columnPurchasePrice(); // *Point!
     *     purchaseCB.query().setPaymentCompleteFlg_Equal_True();
     * });
     * 
* @param scalarCBLambda The callback for sub-query of myself. (NotNull) * @return The decorator of ScalarCondition. e.g. you can use partition-by. (NotNull) */ public HpSSQDecorator sum(SubQuery scalarCBLambda) { assertSubQuery(scalarCBLambda); final HpSSQOption option = createOption(); _setupper.setup("sum", scalarCBLambda, option); return createDecorator(option); } /** * Set up the sub query of myself for the scalar 'avg'. *
     * cb.query().scalar_Equal().avg(purchaseCB -> {
     *     purchaseCB.specify().columnPurchasePrice(); // *Point!
     *     purchaseCB.query().setPaymentCompleteFlg_Equal_True();
     * });
     * 
* @param scalarCBLambda The callback for sub-query of myself. (NotNull) * @return The decorator of ScalarCondition. e.g. you can use partition-by. (NotNull) */ public HpSSQDecorator avg(SubQuery scalarCBLambda) { assertSubQuery(scalarCBLambda); final HpSSQOption option = createOption(); _setupper.setup("avg", scalarCBLambda, option); return createDecorator(option); } // =================================================================================== // Assist Helper // ============= protected HpSSQOption createOption() { return new HpSSQOption(); } protected HpSSQDecorator createDecorator(HpSSQOption option) { return new HpSSQDecorator(option); } protected void assertSubQuery(SubQuery scalarCBLambda) { if (scalarCBLambda == null) { String msg = "The argument 'scalarCBLambda' for ScalarCondition should not be null."; throw new IllegalArgumentException(msg); } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy