Adición temporal
{number,tnumber} + {number,tnumber} → tnumber
SELECT tint '[2@2001-01-01, 2@2001-01-04)' + 1; -- [3@2001-01-01, 3@2001-01-04) SELECT tfloat '[2@2001-01-01, 2@2001-01-04)' + tfloat '[1@2001-01-01, 4@2001-01-04)'; -- [3@2001-01-01, 6@2001-01-04) SELECT tfloat '[1@2001-01-01, 4@2001-01-04)' + tfloat '{[1@2001-01-01, 2@2001-01-02), [1@2001-01-02, 2@2001-01-04)}'; -- {[2@2001-01-01, 4@2001-01-04), [3@2001-01-02, 6@2001-01-04)}
Resta temporal
{number,tnumber} - {number,tnumber} → tnumber
SELECT tint '[1@2001-01-01, 1@2001-01-04)' - tint '[2@2001-01-03, 2@2001-01-05)'; -- [-1@2001-01-03, -1@2001-01-04) SELECT tfloat '[3@2001-01-01, 6@2001-01-04)' - tfloat '[2@2001-01-01, 2@2001-01-04)'; -- [1@2001-01-01, 4@2001-01-04)
Multiplicación temporal
{number,tnumber} * {number,tnumber} → tnumber
SELECT tint '[1@2001-01-01, 4@2001-01-04]' * 2; -- [2@2001-01-01, 8@2001-01-04] SELECT tfloat '[1@2001-01-01, 4@2001-01-04)' * tfloat '[2@2001-01-01, 2@2001-01-04)'; -- [2@2001-01-01, 8@2001-01-04) SELECT tfloat '[1@2001-01-01, 3@2001-01-03)' * '[3@2001-01-01, 1@2001-01-03)'; -- {[3@2001-01-01, 4@2001-01-02, 3@2001-01-03)}
División temporal
{number,tnumber} / {number,tnumber} → tnumber
La función genera un error si el denominador es alguna vez igual a cero durante el intervalo de tiempo común de los argumentos.
SELECT 2 / tfloat '[1@2001-01-01, 3@2001-01-04)'; -- [2@2001-01-01, 0.666666666666667@2001-01-04) SELECT tfloat '[1@2001-01-01, 5@2001-01-05)' / tfloat '[5@2001-01-01, 1@2001-01-05)'; -- {[0.2@2001-01-01, 1@2001-01-03,2001-01-03, 5@2001-01-03,2001-01-05)} SELECT 2 / tfloat '[-1@2001-01-01, 1@2001-01-02]'; -- ERROR: Division by zero SELECT tfloat '[-1@2001-01-04, 1@2001-01-05]' / tfloat '[-1@2001-01-01, 1@2001-01-05]'; -- [-2@2001-01-04, 1@2001-01-05]
Devuelve el valor absoluto del número temporal
abs(tnumber) → tnumber
SELECT abs(tfloat '[1@2001-01-01, -1@2001-01-03, 1@2001-01-05]'); -- [1@2001-01-01, 0@2001-01-02, 1@2001-01-03, 0@2001-01-04, 1@2001-01-05], SELECT abs(tint '[1@2001-01-01, -1@2001-01-03, 1@2001-01-05]'); -- [1@2001-01-01, 1@2001-01-05]
Devuelve la diferencia de valor entre instantes consectivos del número temporal
deltaValue(tnumber) → tnumber
SELECT deltaValue(tint '[1@2001-01-01, 2@2001-01-02, 1@2001-01-03]'); -- [1@2001-01-01, -1@2001-01-02, -1@2001-01-03) SELECT deltaValue(tfloat '{[1.5@2001-01-01, 2@2001-01-02, 1@2001-01-03], [2@2001-01-04, 2@2001-01-05]}'); /* Interp=Step;{[0.5@2001-01-01, -1@2001-01-02, -1@2001-01-03), [0@2001-01-04, 0@2001-01-05)} */
Redondear al entero inferior o superior
floor(tfloat) → tfloat
ceil(tfloat) → tfloat
SELECT floor(tfloat '[0.5@2001-01-01, 1.5@2001-01-02]'); -- [0@2001-01-01, 1@2001-01-02] SELECT ceil(tfloat '[0.5@2001-01-01, 0.6@2001-01-02, 0.7@2001-01-03]'); -- [1@2001-01-01, 1@2001-01-03]
Redondear a un número de posiciones decimales
round(tfloat,integer=0) → tfloat
SELECT round(tfloat '[0.785398163397448@2001-01-01, 2.356194490192345@2001-01-02]', 2); -- [0.79@2001-01-01, 2.36@2001-01-02]
Convertir a grados o radianes
degrees({float,tfloat},normalize=false) → tfloat
radians(tfloat) → tfloat
El parámetro adicional en la función degrees
puede ser utilizado para normalizar los valores entre 0 y 360 grados.
SELECT degrees(pi() * 5); -- 900 SELECT degrees(pi() * 5, true); -- 180 SELECT round(degrees(tfloat '[0.785398163397448@2001-01-01, 2.356194490192345@2001-01-02]')); -- [45@2001-01-01, 135@2001-01-02] SELECT radians(tfloat '[45@2001-01-01, 135@2001-01-02]'); -- [0.785398163397448@2001-01-01, 2.356194490192345@2001-01-02]
Devuelve la derivada sobre el tiempo del número flotante temporal en unidades por segundo
derivative(tfloat) → tfloat
El número flotante temporal debe tener interpolación linear
SELECT derivative(tfloat '{[0@2001-01-01, 10@2001-01-02, 5@2001-01-03], [1@2001-01-04, 0@2001-01-05]}') * 3600 * 24; /* Interp=Step;{[-10@2001-01-01, 5@2001-01-02, 5@2001-01-03], [1@2001-01-04, 1@2001-01-05]} */ SELECT derivative(tfloat 'Interp=Step;[0@2001-01-01, 10@2001-01-02, 5@2001-01-03]'); -- ERROR: The temporal value must have linear interpolation
Devuelve el logaritmo natural y el logaritmo base 10 de un número flotante temporal
ln(tfloat) → tfloat
log10(tfloat) → tfloat
El número flotante temporal no puede ser cero o negativo
SELECT ln(tfloat '{[1@2001-01-01, 10@2001-01-02, 5@2001-01-03], [1@2001-01-04, 1@2001-01-05]}'); /* {[0@2001-01-01, 2.302585092994046@2001-01-02, 1.6094379124341@2001-01-03], [0@2001-01-04, 0@2001-01-05]} */ SELECT log10(tfloat 'Interp=Step;[-10@2001-01-01, 10@2001-01-02]'); -- ERROR: Cannot take logarithm of zero or a negative number
Devuelve el exponencial (e elevado a la potencia dada) de un número flotante temporal
exp(tfloat) → tfloat
SELECT exp(tfloat '{[1@2001-01-01, 10@2001-01-02], [1@2001-01-04, 1@2001-01-05]}'); /* {[2.718281828459045@2001-01-01, 22026.465794806718@2001-01-02], [2.718281828459045@2001-01-04, 2.718281828459045@2001-01-05]} */ SELECT exp(tfloat '{-10@2001-01-01, 0@2001-01-02, 10@2001-01-03}'); -- {0.000045399929762@2001-01-01, 1@2001-01-02, 22026.465794806718@2001-01-03}