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

org.firebirdsql.jdbc.escape.TimestampAddFunction Maven / Gradle / Ivy

There is a newer version: 6.0.0-beta-1
Show newest version
/*
 * Firebird Open Source JDBC Driver
 *
 * Distributable under LGPL license.
 * You may obtain a copy of the License at http://www.gnu.org/copyleft/lgpl.html
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * LGPL License for more details.
 *
 * This file was created by members of the firebird development team.
 * All individual contributions remain the Copyright (C) of those
 * individuals.  Contributors to this file are either listed here or
 * can be obtained from a source control history command.
 *
 * All rights reserved.
 */
package org.firebirdsql.jdbc.escape;

import java.util.Locale;

/**
 * Implements the {@code TIMESTAMPADD} JDBC escape.
 * 

* Value {@code SQL_TSI_FRAC_SECOND} unit is nanoseconds and will be simulated by using {@code MILLISECOND} and * the count multiplied by {@code 1.0e-6} to convert the value to milliseconds. *

*

* Value {@code SQL_TSI_QUARTER} will be simulated by using {@code MONTH} and the count multiplied by {@code 3}. *

* * @author Mark Rotteveel * @since 4.0 */ final class TimestampAddFunction implements SQLFunction { @Override public String apply(String... parameters) throws FBSQLParseException { if (parameters.length != 3) { throw new FBSQLParseException("Expected 3 parameters for TIMESTAMPADD, received " + parameters.length); } String jdbcIntervalName = parameters[0].trim().toUpperCase(Locale.ROOT); if ("SQL_TSI_QUARTER".equals(jdbcIntervalName)) { return "DATEADD(MONTH,3*(" + parameters[1] + ")," + parameters[2] + ")"; } else if ("SQL_TSI_FRAC_SECOND".equals(jdbcIntervalName)) { // See ODBC spec: "where fractional seconds are expressed in billionths of a second." return "DATEADD(MILLISECOND,1.0e-6*(" + parameters[1] + ")," + parameters[2] + ")"; } String fbIntervalName = IntervalMapping.getFirebirdInterval(jdbcIntervalName); return "DATEADD(" + fbIntervalName + "," + parameters[1] + "," + parameters[2] + ")"; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy