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

org.dbflute.cbean.coption.ColumnConversionOption 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.coption;

import org.dbflute.cbean.dream.SpecifiedColumn;

/**
 * The conversion option for column. e.g. ColumnQuery 
* You can filter an aggregate function by scalar function filters. * @author jflute */ public class ColumnConversionOption extends FunctionFilterOption { // =================================================================================== // Function Option // =============== /** * Set the value for coalesce function.
* If you set string value and the derived column is date type, it converts it to a date object internally. * For example, "2010-10-30 12:34:56.789", "2010/10/30" and so on ... are acceptable. * @param coalesce An alternate value when group function returns null. (NullAllowed: if null, no coalesce) * @return this. (NotNull) */ public ColumnConversionOption coalesce(Object coalesce) { doCoalesce(coalesce); return this; } /** * Round the specified part of the number. * @param round Decimal digits or date format for round. (NullAllowed: if null, no round) * @return this. (NotNull) */ public ColumnConversionOption round(Object round) { doRound(round); return this; } /** * Truncate the specified part of the number or date-time value. * @param trunc Decimal digits or date option for trunc. (NullAllowed: if null, no trunc) * @return this. (NotNull) */ public ColumnConversionOption trunc(Object trunc) { doTrunc(trunc); return this; } // =================================================================================== // Purpose Option // ============== // ----------------------------------------------------- // Truncate Date // ------------- /** * Truncate the month and day and time part of the date or the date-time value. *
     *  e.g. 2012/12/31 01:50:46 -> 2012/01/01 00:00:00
     * 
* @return this. (NotNull) */ public ColumnConversionOption truncMonth() { doTruncMonth(); return this; } /** * Truncate the day and time part of the date or the date-time value. *
     *  e.g. 2012/12/31 01:50:46 -> 2012/12/01 00:00:00
     * 
* @return this. (NotNull) */ public ColumnConversionOption truncDay() { doTruncDay(); return this; } /** * Truncate the time part of the date-time value. *
     *  e.g. 2012/12/31 01:50:46 -> 2012/12/31 00:00:00
     * 
* @return this. (NotNull) */ public ColumnConversionOption truncTime() { doTruncTime(); return this; } // ----------------------------------------------------- // Add Date, Year // -------------- /** * Add years to the date or date-time value. * @param addedYear The count of added years. (NullAllowed: if null, no dateAdd) * @return this. (NotNull) */ public ColumnConversionOption addYear(Integer addedYear) { doAddYear(addedYear); return this; } /** * Add to the date or date-time value by the specified years column.
* Plus only, if you want minus, use substractYear() method. *
     * e.g. ColumnQuery: ... > PURCHASE_DATETIME + (PURCHASE_COUNT years)
     *  PurchaseCB cb = new PurchaseCB();
     *  cb.columnQuery(new SpecifyQuery() {
     *      public void specify(Purchase cb) {
     *          cb.column...();
     *      }
     *  }).greaterThan(new SpecifyQuery() {
     *      public void specify(Purchase cb) {
     *          cb.columnPurchaseDatetime();
     *      }
     *  }).convert(new ColumnConversionOption()
     *          .addYear(cb.dreamCruiseCB().specify().columnPurchaseCount());
     * 
* @param addedColumn The added column specified by your Dream. (NullAllowed: if null, no dateAdd) * @return this. (NotNull) */ public ColumnConversionOption addYear(SpecifiedColumn addedColumn) { doAddYear(addedColumn); return this; } /** * Subtract to the date or date-time value by the specified years column. *
     * e.g. ColumnQuery: ... > PURCHASE_DATETIME - (PURCHASE_COUNT years)
     *  PurchaseCB cb = new PurchaseCB();
     *  cb.columnQuery(new SpecifyQuery() {
     *      public void specify(Purchase cb) {
     *          cb.column...();
     *      }
     *  }).greaterThan(new SpecifyQuery() {
     *      public void specify(Purchase cb) {
     *          cb.columnPurchaseDatetime();
     *      }
     *  }).convert(new ColumnConversionOption()
     *          .subtractYear(cb.dreamCruiseCB().specify().columnPurchaseCount());
     * 
* @param subtractedColumn The subtracted column specified by your Dream. (NullAllowed: if null, no dateAdd) * @return this. (NotNull) */ public ColumnConversionOption subtractYear(SpecifiedColumn subtractedColumn) { doAddYear(subtractedColumn, true); return this; } // ----------------------------------------------------- // Add Date, Month // --------------- /** * Add months to the date or date-time value. * @param addedMonth The count of added months. (NullAllowed: if null, no dateAdd) * @return this. (NotNull) */ public ColumnConversionOption addMonth(Integer addedMonth) { doAddMonth(addedMonth); return this; } /** * Add to the date or date-time value by the specified months column.
* Plus only, if you want minus, use substractMonth() method. *
     * e.g. ColumnQuery: ... > PURCHASE_DATETIME + (PURCHASE_COUNT months)
     *  PurchaseCB cb = new PurchaseCB();
     *  cb.columnQuery(new SpecifyQuery() {
     *      public void specify(Purchase cb) {
     *          cb.column...();
     *      }
     *  }).greaterThan(new SpecifyQuery() {
     *      public void specify(Purchase cb) {
     *          cb.columnPurchaseDatetime();
     *      }
     *  }).convert(new ColumnConversionOption()
     *          .addMonth(cb.dreamCruiseCB().specify().columnPurchaseCount());
     * 
* @param addedColumn The added column specified by your Dream. (NullAllowed: if null, no dateAdd) * @return this. (NotNull) */ public ColumnConversionOption addMonth(SpecifiedColumn addedColumn) { doAddMonth(addedColumn); return this; } /** * Subtract to the date or date-time value by the specified months column. *
     * e.g. ColumnQuery: ... > PURCHASE_DATETIME - (PURCHASE_COUNT months)
     *  PurchaseCB cb = new PurchaseCB();
     *  cb.columnQuery(new SpecifyQuery() {
     *      public void specify(Purchase cb) {
     *          cb.column...();
     *      }
     *  }).greaterThan(new SpecifyQuery() {
     *      public void specify(Purchase cb) {
     *          cb.columnPurchaseDatetime();
     *      }
     *  }).convert(new ColumnConversionOption()
     *          .subtractMonth(cb.dreamCruiseCB().specify().columnPurchaseCount());
     * 
* @param subtractedColumn The subtracted column specified by your Dream. (NullAllowed: if null, no dateAdd) * @return this. (NotNull) */ public ColumnConversionOption subtractMonth(SpecifiedColumn subtractedColumn) { doAddMonth(subtractedColumn, true); return this; } // ----------------------------------------------------- // Add Date, Day // ------------- /** * Add days to the date or date-time value. * @param addedDay The count of added days. (NullAllowed: if null, no dateAdd) * @return this. (NotNull) */ public ColumnConversionOption addDay(Integer addedDay) { doAddDay(addedDay); return this; } /** * Add to the date or date-time value by the specified days column.
* Plus only, if you want minus, use substractDay() method. *
     * e.g. ColumnQuery: ... > PURCHASE_DATETIME + (PURCHASE_COUNT days)
     *  PurchaseCB cb = new PurchaseCB();
     *  cb.columnQuery(new SpecifyQuery() {
     *      public void specify(Purchase cb) {
     *          cb.column...();
     *      }
     *  }).greaterThan(new SpecifyQuery() {
     *      public void specify(Purchase cb) {
     *          cb.columnPurchaseDatetime();
     *      }
     *  }).convert(new ColumnConversionOption()
     *          .addDay(cb.dreamCruiseCB().specify().columnPurchaseCount());
     * 
* @param addedColumn The added column specified by your Dream. (NullAllowed: if null, no dateAdd) * @return this. (NotNull) */ public ColumnConversionOption addDay(SpecifiedColumn addedColumn) { doAddDay(addedColumn); return this; } /** * Subtract to the date or date-time value by the specified days column. *
     * e.g. ColumnQuery: ... > PURCHASE_DATETIME - (PURCHASE_COUNT days)
     *  PurchaseCB cb = new PurchaseCB();
     *  cb.columnQuery(new SpecifyQuery() {
     *      public void specify(Purchase cb) {
     *          cb.column...();
     *      }
     *  }).greaterThan(new SpecifyQuery() {
     *      public void specify(Purchase cb) {
     *          cb.columnPurchaseDatetime();
     *      }
     *  }).convert(new ColumnConversionOption()
     *          .subtractDay(cb.dreamCruiseCB().specify().columnPurchaseCount());
     * 
* @param subtractedColumn The subtracted column specified by your Dream. (NullAllowed: if null, no dateAdd) * @return this. (NotNull) */ public ColumnConversionOption subtractDay(SpecifiedColumn subtractedColumn) { doAddDay(subtractedColumn, true); return this; } // ----------------------------------------------------- // Add Date, Hour // -------------- /** * Add hours to date-time value. * @param addedHour The count of added hours. (NullAllowed: if null, no dateAdd) * @return this. (NotNull) */ public ColumnConversionOption addHour(Integer addedHour) { doAddHour(addedHour); return this; } /** * Add to the date or date-time value by the specified hours column.
* Plus only, if you want minus, use substractHour() method. *
     * e.g. ColumnQuery: ... > PURCHASE_DATETIME + (PURCHASE_COUNT hours)
     *  PurchaseCB cb = new PurchaseCB();
     *  cb.columnQuery(new SpecifyQuery() {
     *      public void specify(Purchase cb) {
     *          cb.column...();
     *      }
     *  }).greaterThan(new SpecifyQuery() {
     *      public void specify(Purchase cb) {
     *          cb.columnPurchaseDatetime();
     *      }
     *  }).convert(new ColumnConversionOption()
     *          .addHour(cb.dreamCruiseCB().specify().columnPurchaseCount());
     * 
* @param addedColumn The added column specified by your Dream. (NullAllowed: if null, no dateAdd) * @return this. (NotNull) */ public ColumnConversionOption addHour(SpecifiedColumn addedColumn) { doAddHour(addedColumn); return this; } /** * Subtract to the date or date-time value by the specified hours column. *
     * e.g. ColumnQuery: ... > PURCHASE_DATETIME - (PURCHASE_COUNT hours)
     *  PurchaseCB cb = new PurchaseCB();
     *  cb.columnQuery(new SpecifyQuery() {
     *      public void specify(Purchase cb) {
     *          cb.column...();
     *      }
     *  }).greaterThan(new SpecifyQuery() {
     *      public void specify(Purchase cb) {
     *          cb.columnPurchaseDatetime();
     *      }
     *  }).convert(new ColumnConversionOption()
     *          .subtractHour(cb.dreamCruiseCB().specify().columnPurchaseCount());
     * 
* @param subtractedColumn The subtracted column specified by your Dream. (NullAllowed: if null, no dateAdd) * @return this. (NotNull) */ public ColumnConversionOption subtractHour(SpecifiedColumn subtractedColumn) { doAddHour(subtractedColumn, true); return this; } // ----------------------------------------------------- // Add Date, Minute // ---------------- /** * Add minutes to date-time value. * @param addedMinute The count of added minutes. (NullAllowed: if null, no dateAdd) * @return this. (NotNull) */ public ColumnConversionOption addMinute(Integer addedMinute) { doAddMinute(addedMinute); return this; } /** * Add to the date or date-time value by the specified minutes column.
* Plus only, if you want minus, use substractMinute() method. *
     * e.g. ColumnQuery: ... > PURCHASE_DATETIME + (PURCHASE_COUNT minutes)
     *  PurchaseCB cb = new PurchaseCB();
     *  cb.columnQuery(new SpecifyQuery() {
     *      public void specify(Purchase cb) {
     *          cb.column...();
     *      }
     *  }).greaterThan(new SpecifyQuery() {
     *      public void specify(Purchase cb) {
     *          cb.columnPurchaseDatetime();
     *      }
     *  }).convert(new ColumnConversionOption()
     *          .addMinute(cb.dreamCruiseCB().specify().columnPurchaseCount());
     * 
* @param addedColumn The added column specified by your Dream. (NullAllowed: if null, no dateAdd) * @return this. (NotNull) */ public ColumnConversionOption addMinute(SpecifiedColumn addedColumn) { doAddMinute(addedColumn); return this; } /** * Subtract to the date or date-time value by the specified minutes column. *
     * e.g. ColumnQuery: ... > PURCHASE_DATETIME - (PURCHASE_COUNT minutes)
     *  PurchaseCB cb = new PurchaseCB();
     *  cb.columnQuery(new SpecifyQuery() {
     *      public void specify(Purchase cb) {
     *          cb.column...();
     *      }
     *  }).greaterThan(new SpecifyQuery() {
     *      public void specify(Purchase cb) {
     *          cb.columnPurchaseDatetime();
     *      }
     *  }).convert(new ColumnConversionOption()
     *          .subtractMinute(cb.dreamCruiseCB().specify().columnPurchaseCount());
     * 
* @param subtractedColumn The subtracted column specified by your Dream. (NullAllowed: if null, no dateAdd) * @return this. (NotNull) */ public ColumnConversionOption subtractMinute(SpecifiedColumn subtractedColumn) { doAddMinute(subtractedColumn, true); return this; } // ----------------------------------------------------- // Add Date, Second // ---------------- /** * Add seconds to date-time value. * @param addedSecond The count of added seconds. (NullAllowed: if null, no dateAdd) * @return this. (NotNull) */ public ColumnConversionOption addSecond(Integer addedSecond) { doAddSecond(addedSecond); return this; } /** * Add to the date or date-time value by the specified seconds column.
* Plus only, if you want minus, use substractSecond() method. *
     * e.g. ColumnQuery: ... > PURCHASE_DATETIME + (PURCHASE_COUNT seconds)
     *  PurchaseCB cb = new PurchaseCB();
     *  cb.columnQuery(new SpecifyQuery() {
     *      public void specify(Purchase cb) {
     *          cb.column...();
     *      }
     *  }).greaterThan(new SpecifyQuery() {
     *      public void specify(Purchase cb) {
     *          cb.columnPurchaseDatetime();
     *      }
     *  }).convert(new ColumnConversionOption()
     *          .addSecond(cb.dreamCruiseCB().specify().columnPurchaseCount());
     * 
* @param addedColumn The added column specified by your Dream. (NullAllowed: if null, no dateAdd) * @return this. (NotNull) */ public ColumnConversionOption addSecond(SpecifiedColumn addedColumn) { doAddSecond(addedColumn); return this; } /** * Subtract to the date or date-time value by the specified seconds column. *
     * e.g. ColumnQuery: ... > PURCHASE_DATETIME - (PURCHASE_COUNT seconds)
     *  PurchaseCB cb = new PurchaseCB();
     *  cb.columnQuery(new SpecifyQuery() {
     *      public void specify(Purchase cb) {
     *          cb.column...();
     *      }
     *  }).greaterThan(new SpecifyQuery() {
     *      public void specify(Purchase cb) {
     *          cb.columnPurchaseDatetime();
     *      }
     *  }).convert(new ColumnConversionOption()
     *          .subtractSecond(cb.dreamCruiseCB().specify().columnPurchaseCount());
     * 
* @param subtractedColumn The subtracted column specified by your Dream. (NullAllowed: if null, no dateAdd) * @return this. (NotNull) */ public ColumnConversionOption subtractSecond(SpecifiedColumn subtractedColumn) { doAddSecond(subtractedColumn, true); return this; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy