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

org.dbflute.cbean.dream.ColumnCalculator 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.dream;

import org.dbflute.cbean.coption.ColumnConversionOption;
import org.dbflute.cbean.coption.FunctionFilterOptionCall;

/**
 * The calculator interface of column, also providing one of DreamCruise.
 * @author jflute
 */
public interface ColumnCalculator {

    // ===================================================================================
    //                                                                         Calculation
    //                                                                         ===========
    /**
     * Plus the specified column with the value. (+)
     * @param plusValue The number value for plus. (NotNull)
     * @return this. (NotNull)
     */
    ColumnCalculator plus(Number plusValue);

    /**
     * Plus the specified column with the plus column. (+) {Dream Cruise}
     * 
     * e.g. ManualOrder: order by PURCHASE_PRICE + PURCHASE_COUNT
     *  cb.query().addOrderBy_PurchasePrice_Asc().withManualOrder(op -> {
     *      op.plus(cb.dreamCruiseCB().specify().columnPurchaseCount());
     *  });
     * 
     * e.g. ColumnQuery: ... > PURCHASE_PRICE + PURCHASE_COUNT
     *  cb.columnQuery(colCB -> {
     *      cb.column...();
     *  }).greaterThan(colCB -> {
     *      cb.columnPurchasePrice();
     *  }).plus(cb.dreamCruiseCB().specify().columnPurchaseCount());
     * 
* @param plusColumn The plus column specified by your Dream Cruise. (NotNull) * @return this. (NotNull) */ ColumnCalculator plus(SpecifiedColumn plusColumn); /** * Minus the specified column with the value. (-) * @param minusValue The number value for minus. (NotNull) * @return this. (NotNull) */ ColumnCalculator minus(Number minusValue); /** * Minus the specified column with the minus column. (-) {Dream Cruise} *
     * e.g. ManualOrder: order by PURCHASE_PRICE - PURCHASE_COUNT
     *  cb.query().addOrderBy_PurchasePrice_Asc().withManualOrder(op -> {
     *      op.minus(cb.dreamCruiseCB().specify().columnPurchaseCount());
     *  });
     * 
     * e.g. ColumnQuery: ... > PURCHASE_PRICE - PURCHASE_COUNT
     *  cb.columnQuery(colCB -> {
     *      cb.column...();
     *  }).greaterThan(colCB -> {
     *      cb.columnPurchasePrice();
     *  }).minus(cb.dreamCruiseCB().specify().columnPurchaseCount());
     * 
* @param minusColumn The minus column specified by your Dream Cruise. (NotNull) * @return this. (NotNull) */ ColumnCalculator minus(SpecifiedColumn minusColumn); /** * Multiply the value to the specified column. (*) * @param multiplyValue The number value for multiply. (NotNull) * @return this. (NotNull) */ ColumnCalculator multiply(Number multiplyValue); /** * Multiply the specified column with the multiply column. (*) {Dream Cruise} *
     * e.g. ManualOrder: order by PURCHASE_PRICE * PURCHASE_COUNT
     *  cb.query().addOrderBy_PurchasePrice_Asc().withManualOrder(op -> {
     *      op.multiply(cb.dreamCruiseCB().specify().columnPurchaseCount());
     *  });
     * 
     * e.g. ColumnQuery: ... > PURCHASE_PRICE * PURCHASE_COUNT
     *  cb.columnQuery(colCB -> {
     *      cb.column...();
     *  }).greaterThan(colCB -> {
     *      cb.columnPurchasePrice();
     *  }).multiply(cb.dreamCruiseCB().specify().columnPurchaseCount());
     * 
* @param multiplyColumn The multiply column specified by your Dream Cruise. (NotNull) * @return this. (NotNull) */ ColumnCalculator multiply(SpecifiedColumn multiplyColumn); /** * Divide the specified column by the value. (/) * @param divideValue The number value for divide. (NotNull) * @return this. (NotNull) */ ColumnCalculator divide(Number divideValue); /** * Divide the specified column with the divide column. (/) {Dream Cruise} *
     * e.g. ManualOrder: order by PURCHASE_PRICE / PURCHASE_COUNT
     *  cb.query().addOrderBy_PurchasePrice_Asc().withManualOrder(op -> {
     *      op.divide(cb.dreamCruiseCB().specify().columnPurchaseCount());
     *  });
     * 
     * e.g. ColumnQuery: ... > PURCHASE_PRICE / PURCHASE_COUNT
     *  cb.columnQuery(colCB -> {
     *      cb.column...();
     *  }).greaterThan(colCB -> {
     *      cb.columnPurchasePrice();
     *  }).divide(cb.dreamCruiseCB().specify().columnPurchaseCount());
     * 
* @param divideColumn The divide column specified by your Dream Cruise. (NotNull) * @return this. (NotNull) */ ColumnCalculator divide(SpecifiedColumn divideColumn); /** * Convert the value of right column by function. *
     * ...).convert(op -> op.addDay(8).truncTime());
     * 
* @param opLambda The callback for conversion option of column. (NotNull) * @return this. (NotNull) */ ColumnCalculator convert(FunctionFilterOptionCall opLambda); // =================================================================================== // Left/Right Mode // =============== /** * To be for left column. * @return this. (NotNull) */ ColumnCalculator left(); /** * To be for right column. (default)
* It also means main process internally. * @return this. (NotNull) */ ColumnCalculator right(); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy