2007-04-15 03:11:35 +02:00
|
|
|
=================
|
|
|
|
Builtin functions
|
|
|
|
=================
|
|
|
|
|
|
|
|
Builtin functions below (except DECODE) are used only if there is no
|
|
|
|
UDF declared with the same name.
|
|
|
|
This choice of UDF or system function is decided when compiling the
|
|
|
|
statement and isn't changed if the statement is stored (trigger / SP).
|
|
|
|
|
|
|
|
Authors:
|
|
|
|
Adriano dos Santos Fernandes <adrianosf@uol.com.br>
|
|
|
|
Oleg Loa <loa@mail.ru>
|
|
|
|
Alexey Karyakin <aleksey.karyakin@mail.ru>
|
2008-04-14 15:21:05 +02:00
|
|
|
Claudio Valderrama C. <cvalde at usa.net>
|
2007-04-15 03:11:35 +02:00
|
|
|
|
|
|
|
|
|
|
|
---
|
|
|
|
ABS
|
|
|
|
---
|
|
|
|
|
|
|
|
Function:
|
|
|
|
Returns the absolute value of a number.
|
|
|
|
|
|
|
|
Format:
|
|
|
|
ABS( <number> )
|
|
|
|
|
|
|
|
Example:
|
|
|
|
select abs(amount) from transactions;
|
|
|
|
|
|
|
|
|
|
|
|
----
|
|
|
|
ACOS
|
|
|
|
----
|
|
|
|
|
|
|
|
Function:
|
|
|
|
Returns the arc cosine of a number.
|
|
|
|
|
|
|
|
Format:
|
|
|
|
ACOS( <number> )
|
|
|
|
|
|
|
|
Notes:
|
|
|
|
Argument to ACOS must be in the range -1 to 1 and returns a value in
|
|
|
|
the range 0 to PI.
|
|
|
|
|
|
|
|
Example:
|
|
|
|
select acos(x) from y;
|
|
|
|
|
|
|
|
|
|
|
|
----------
|
|
|
|
ASCII_CHAR
|
|
|
|
----------
|
|
|
|
|
|
|
|
Function:
|
|
|
|
Returns the ASCII character with the specified code.
|
|
|
|
|
|
|
|
Format:
|
|
|
|
ASCII_CHAR( <number> )
|
|
|
|
|
|
|
|
Notes:
|
|
|
|
Argument to ASCII_CHAR must be in the range 0 to 255 and returns a value
|
|
|
|
with NONE character set.
|
|
|
|
|
|
|
|
Example:
|
|
|
|
select ascii_char(x) from y;
|
|
|
|
|
|
|
|
|
|
|
|
---------
|
|
|
|
ASCII_VAL
|
|
|
|
---------
|
|
|
|
|
|
|
|
Function:
|
|
|
|
Returns the ASCII code of the first character of the specified string.
|
|
|
|
|
|
|
|
Format:
|
|
|
|
ASCII_VAL( <string> )
|
|
|
|
|
|
|
|
Notes:
|
2007-04-21 23:27:22 +02:00
|
|
|
1) Returns 0 if the string is empty.
|
2007-04-24 08:11:08 +02:00
|
|
|
2) Throws error if the first character is multi-byte.
|
2007-04-15 03:11:35 +02:00
|
|
|
|
|
|
|
Example:
|
|
|
|
select ascii_val(x) from y;
|
|
|
|
|
|
|
|
|
|
|
|
----
|
|
|
|
ASIN
|
|
|
|
----
|
|
|
|
|
|
|
|
Function:
|
|
|
|
Returns the arc sine of a number.
|
|
|
|
|
|
|
|
Format:
|
|
|
|
ASIN( <number> )
|
|
|
|
|
|
|
|
Notes:
|
|
|
|
Argument to ASIN must be in the range -1 to 1 and returns a value in
|
|
|
|
the range -PI / 2 to PI / 2.
|
|
|
|
|
|
|
|
Example:
|
|
|
|
select asin(x) from y;
|
|
|
|
|
|
|
|
|
|
|
|
----
|
|
|
|
ATAN
|
|
|
|
----
|
|
|
|
|
|
|
|
Function:
|
|
|
|
Returns the arc tangent of a number.
|
|
|
|
|
|
|
|
Format:
|
|
|
|
ATAN( <number> )
|
|
|
|
|
|
|
|
Notes:
|
|
|
|
Returns a value in the range -PI / 2 to PI / 2.
|
|
|
|
|
|
|
|
Example:
|
|
|
|
select atan(x) from y;
|
|
|
|
|
|
|
|
|
|
|
|
-----
|
|
|
|
ATAN2
|
|
|
|
-----
|
|
|
|
|
|
|
|
Function:
|
|
|
|
Returns the arc tangent of the first number / the second number.
|
|
|
|
|
|
|
|
Format:
|
|
|
|
ATAN( <number>, <number> )
|
|
|
|
|
|
|
|
Notes:
|
|
|
|
Returns a value in the range -PI to PI.
|
|
|
|
|
|
|
|
Example:
|
|
|
|
select atan2(x, y) from z;
|
|
|
|
|
|
|
|
|
|
|
|
-------
|
|
|
|
BIN_AND
|
|
|
|
-------
|
|
|
|
|
|
|
|
Function:
|
|
|
|
Returns the result of a binary AND operation performed on all arguments.
|
|
|
|
|
|
|
|
Format:
|
2008-04-14 13:09:16 +02:00
|
|
|
BIN_AND( <number>, <number> [, <number> ...] )
|
2007-04-15 03:11:35 +02:00
|
|
|
|
|
|
|
Example:
|
|
|
|
select bin_and(flags, 1) from x;
|
|
|
|
|
|
|
|
|
2008-04-14 13:09:16 +02:00
|
|
|
-------
|
|
|
|
BIN_NOT
|
|
|
|
-------
|
|
|
|
|
|
|
|
Function:
|
|
|
|
Returns the result of a bitwise NOT operation performed on its argument.
|
|
|
|
|
|
|
|
Format:
|
|
|
|
BIN_NOT( <number> )
|
|
|
|
|
|
|
|
Example:
|
|
|
|
select bin_not(flags) from x;
|
|
|
|
|
|
|
|
|
2007-04-15 03:11:35 +02:00
|
|
|
------
|
|
|
|
BIN_OR
|
|
|
|
------
|
|
|
|
|
|
|
|
Function:
|
|
|
|
Returns the result of a binary OR operation performed on all arguments.
|
|
|
|
|
|
|
|
Format:
|
2008-04-14 13:09:16 +02:00
|
|
|
BIN_OR( <number>, <number> [, <number> ...] )
|
2007-04-15 03:11:35 +02:00
|
|
|
|
|
|
|
Example:
|
|
|
|
select bin_or(flags1, flags2) from x;
|
|
|
|
|
|
|
|
|
|
|
|
-------
|
|
|
|
BIN_SHL
|
|
|
|
-------
|
|
|
|
|
|
|
|
Function:
|
|
|
|
Returns the result of a binary shift left operation performed on the arguments (first << second).
|
|
|
|
|
|
|
|
Format:
|
|
|
|
BIN_SHL( <number>, <number> )
|
|
|
|
|
|
|
|
Example:
|
|
|
|
select bin_shl(flags1, 1) from x;
|
|
|
|
|
|
|
|
|
|
|
|
-------
|
|
|
|
BIN_SHR
|
|
|
|
-------
|
|
|
|
|
|
|
|
Function:
|
|
|
|
Returns the result of a binary shift right operation performed on the arguments (first >> second).
|
|
|
|
|
|
|
|
Format:
|
|
|
|
BIN_SHR( <number>, <number> )
|
|
|
|
|
|
|
|
Example:
|
|
|
|
select bin_shr(flags1, 1) from x;
|
|
|
|
|
|
|
|
|
|
|
|
-------
|
|
|
|
BIN_XOR
|
|
|
|
-------
|
|
|
|
|
|
|
|
Function:
|
|
|
|
Returns the result of a binary XOR operation performed on all arguments.
|
|
|
|
|
|
|
|
Format:
|
2008-04-14 13:09:16 +02:00
|
|
|
BIN_XOR( <number>, <number> [, <number> ...] )
|
2007-04-15 03:11:35 +02:00
|
|
|
|
|
|
|
Example:
|
|
|
|
select bin_xor(flags1, flags2) from x;
|
|
|
|
|
|
|
|
|
|
|
|
--------------
|
|
|
|
CEIL | CEILING
|
|
|
|
--------------
|
|
|
|
|
|
|
|
Function:
|
|
|
|
Returns a value representing the smallest integer that is greater
|
|
|
|
than or equal to the input argument.
|
|
|
|
|
|
|
|
Format:
|
|
|
|
{ CEIL | CEILING }( <number> )
|
|
|
|
|
|
|
|
Example:
|
2007-04-21 23:27:22 +02:00
|
|
|
1) select ceil(val) from x;
|
|
|
|
2) select ceil(2.1), ceil(-2.1) from rdb$database; -- returns 3, -2
|
2007-04-15 03:11:35 +02:00
|
|
|
|
|
|
|
|
2008-05-09 17:27:31 +02:00
|
|
|
------------
|
|
|
|
CHAR_TO_UUID
|
|
|
|
------------
|
|
|
|
|
|
|
|
Function:
|
|
|
|
Converts the CHAR(32) ASCII representation of an UUID
|
|
|
|
(XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX) to the CHAR(16) OCTETS
|
|
|
|
representation (optimized for storage).
|
|
|
|
|
|
|
|
Format:
|
|
|
|
CHAR_TO_UUID( <string> )
|
|
|
|
|
2012-07-10 18:00:27 +02:00
|
|
|
Important (for big-endian servers):
|
|
|
|
It has been discovered that before Firebird 2.5.2, CHAR_TO_UUID and UUID_TO_CHAR works
|
|
|
|
incorrectly in big-endian servers. In these machines, bytes/characters are swapped and goes in
|
|
|
|
wrong positions when converting. This bug was fixed in 2.5.2 and 3.0, but that means these
|
|
|
|
functions now returns different values (for the same input parameter) than before.
|
2011-12-21 15:45:39 +01:00
|
|
|
|
2008-05-09 17:27:31 +02:00
|
|
|
Example:
|
|
|
|
select char_to_uuid('93519227-8D50-4E47-81AA-8F6678C096A1') from rdb$database;
|
|
|
|
|
2012-07-10 18:00:27 +02:00
|
|
|
See also: GEN_UUID and UUID_TO_CHAR
|
2008-05-09 17:27:31 +02:00
|
|
|
|
|
|
|
|
2007-04-15 03:11:35 +02:00
|
|
|
---
|
|
|
|
COS
|
|
|
|
---
|
|
|
|
|
|
|
|
Function:
|
2008-04-25 13:00:55 +02:00
|
|
|
Returns the cosine of an angle (expressed in radians).
|
2007-04-15 03:11:35 +02:00
|
|
|
|
|
|
|
Format:
|
|
|
|
COS( <number> )
|
|
|
|
|
|
|
|
Notes:
|
|
|
|
The angle is specified in radians and returns a value in the range -1 to 1.
|
|
|
|
|
|
|
|
Example:
|
|
|
|
select cos(x) from y;
|
|
|
|
|
|
|
|
|
|
|
|
----
|
|
|
|
COSH
|
|
|
|
----
|
|
|
|
|
|
|
|
Function:
|
2008-04-25 13:00:55 +02:00
|
|
|
Returns the hyperbolic cosine of an angle (expressed in radians).
|
2007-04-15 03:11:35 +02:00
|
|
|
|
|
|
|
Format:
|
|
|
|
COSH( <number> )
|
|
|
|
|
|
|
|
Example:
|
|
|
|
select cosh(x) from y;
|
|
|
|
|
|
|
|
|
|
|
|
---
|
|
|
|
COT
|
|
|
|
---
|
|
|
|
|
|
|
|
Function:
|
|
|
|
Returns 1 / tan(argument).
|
|
|
|
|
|
|
|
Format:
|
|
|
|
COT( <number> )
|
|
|
|
|
|
|
|
Example:
|
|
|
|
select cot(x) from y;
|
|
|
|
|
|
|
|
|
|
|
|
-------
|
|
|
|
DATEADD
|
|
|
|
-------
|
|
|
|
|
|
|
|
Function:
|
|
|
|
Returns a date/time/timestamp value increased (or decreased, when negative)
|
|
|
|
by the specified amount of time.
|
|
|
|
|
|
|
|
Format:
|
2007-10-06 18:07:31 +02:00
|
|
|
DATEADD( <number> <timestamp_part> TO <date_time> )
|
2007-10-08 03:21:39 +02:00
|
|
|
DATEADD( <timestamp_part>, <number>, <date_time> )
|
2007-04-15 03:11:35 +02:00
|
|
|
|
2008-04-14 15:21:05 +02:00
|
|
|
timestamp_part ::= { YEAR | MONTH | DAY | WEEK | HOUR | MINUTE | SECOND | MILLISECOND }
|
2007-04-15 03:11:35 +02:00
|
|
|
|
|
|
|
Notes:
|
2008-04-12 14:43:58 +02:00
|
|
|
1) WEEKDAY and YEARDAY cannot be used. It doesn't make sense.
|
|
|
|
2) YEAR, MONTH and DAY could not be used with time values.
|
2007-04-15 03:11:35 +02:00
|
|
|
3) All timestamp_part values could be used with timestamp values.
|
2008-04-13 16:38:39 +02:00
|
|
|
4) When using hour, minute, second and millisecond for DATEADD and dates, the quantity added or
|
2008-04-14 15:21:05 +02:00
|
|
|
subtracted should account at least for one day to produce effect (IE adding 23 hours to a date
|
2008-04-12 14:43:58 +02:00
|
|
|
doesn't increment it).
|
|
|
|
|
2007-04-15 03:11:35 +02:00
|
|
|
Example:
|
2010-08-09 16:50:11 +02:00
|
|
|
select dateadd(-1 day to current_date) as yesterday
|
2007-04-15 03:11:35 +02:00
|
|
|
from rdb$database;
|
|
|
|
|
|
|
|
|
|
|
|
--------
|
|
|
|
DATEDIFF
|
|
|
|
--------
|
|
|
|
|
|
|
|
Function:
|
2007-04-21 23:27:22 +02:00
|
|
|
Returns an exact numeric value representing the amount of time from the first
|
|
|
|
date/time/timestamp value to the second one.
|
2007-04-15 03:11:35 +02:00
|
|
|
|
|
|
|
Format:
|
2007-10-02 17:37:38 +02:00
|
|
|
DATEDIFF( <timestamp_part> FROM <date_time> TO <date_time> )
|
2007-04-15 03:11:35 +02:00
|
|
|
DATEDIFF( <timestamp_part>, <date_time>, <date_time> )
|
|
|
|
|
2008-04-14 15:21:05 +02:00
|
|
|
timestamp_part ::= { YEAR | MONTH | DAY | WEEK | HOUR | MINUTE | SECOND | MILLISECOND }
|
2008-04-12 14:43:58 +02:00
|
|
|
|
2007-04-15 03:11:35 +02:00
|
|
|
Notes:
|
|
|
|
1) Returns positive value if the second value is greater than the first one,
|
|
|
|
negative when the first one is greater or zero when they are equal.
|
2007-04-15 13:56:14 +02:00
|
|
|
2) Comparison of date with time values is invalid.
|
2008-04-12 14:43:58 +02:00
|
|
|
3) WEEKDAY and YEARDAY cannot be used. It doesn't make sense.
|
|
|
|
4) YEAR, MONTH and DAY could not be used with time values.
|
2007-04-15 03:11:35 +02:00
|
|
|
5) All timestamp_part values could be used with timestamp values.
|
|
|
|
|
2008-04-14 15:21:05 +02:00
|
|
|
Example:
|
|
|
|
select datediff(week from cast('yesterday' as timestamp) - 7 to current_timestamp)
|
|
|
|
from rdb$database;
|
|
|
|
|
2007-04-15 03:11:35 +02:00
|
|
|
|
|
|
|
------
|
|
|
|
DECODE
|
|
|
|
------
|
|
|
|
|
|
|
|
Function:
|
|
|
|
DECODE is a shortcut to CASE ... WHEN ... ELSE expression.
|
|
|
|
|
|
|
|
Format:
|
|
|
|
DECODE( <expression>, <search>, <result> [ , <search>, <result> ... ] [, <default> ]
|
|
|
|
|
|
|
|
Example:
|
|
|
|
select decode(state, 0, 'deleted', 1, 'active', 'unknown') from things;
|
|
|
|
|
|
|
|
|
|
|
|
---
|
|
|
|
EXP
|
|
|
|
---
|
|
|
|
|
|
|
|
Function:
|
|
|
|
Returns the exponential e to the argument.
|
|
|
|
|
|
|
|
Format:
|
|
|
|
EXP( <number> )
|
|
|
|
|
|
|
|
Example:
|
|
|
|
select exp(x) from y;
|
|
|
|
|
|
|
|
|
|
|
|
-----
|
|
|
|
FLOOR
|
|
|
|
-----
|
|
|
|
|
|
|
|
Function:
|
|
|
|
Returns a value representing the largest integer that is less
|
|
|
|
than or equal to the input argument.
|
|
|
|
|
|
|
|
Format:
|
|
|
|
FLOOR( <number> )
|
|
|
|
|
|
|
|
Example:
|
2007-04-21 23:27:22 +02:00
|
|
|
1) select floor(val) from x;
|
|
|
|
2) select floor(2.1), floor(-2.1) from rdb$database; -- returns 2, -3
|
2007-04-15 03:11:35 +02:00
|
|
|
|
|
|
|
|
|
|
|
--------
|
|
|
|
GEN_UUID
|
|
|
|
--------
|
|
|
|
|
|
|
|
Function:
|
2008-05-11 05:00:46 +02:00
|
|
|
Returns an universal unique number in CHAR(16) OCTETS type.
|
2007-04-15 03:11:35 +02:00
|
|
|
|
|
|
|
Format:
|
|
|
|
GEN_UUID()
|
|
|
|
|
2012-07-10 18:00:27 +02:00
|
|
|
Important:
|
|
|
|
Before Firebird 2.5.2, GEN_UUID was returning completely random strings. This is not compliant
|
|
|
|
with the RFC-4122 (UUID specification).
|
|
|
|
This was fixed in Firebird 2.5.2 and 3.0. Now GEN_UUID returns a compliant UUID version 4
|
2011-12-21 15:45:39 +01:00
|
|
|
string, where some bits are reserved and the others are random. The string format of a compliant
|
|
|
|
UUID is XXXXXXXX-XXXX-4XXX-YXXX-XXXXXXXXXXXX, where 4 is fixed (version) and Y is 8, 9, A or B.
|
|
|
|
|
2007-04-15 03:11:35 +02:00
|
|
|
Example:
|
|
|
|
insert into records (id) value (gen_uuid());
|
|
|
|
|
2012-07-10 18:00:27 +02:00
|
|
|
See also: CHAR_TO_UUID and UUID_TO_CHAR
|
2008-05-09 17:27:31 +02:00
|
|
|
|
2007-04-15 03:11:35 +02:00
|
|
|
|
|
|
|
----
|
|
|
|
HASH
|
|
|
|
----
|
|
|
|
|
|
|
|
Function:
|
2007-11-30 14:49:09 +01:00
|
|
|
Returns a HASH of a string.
|
2007-04-15 03:11:35 +02:00
|
|
|
|
|
|
|
Format:
|
2007-11-30 14:49:09 +01:00
|
|
|
HASH( <string> )
|
2007-04-15 03:11:35 +02:00
|
|
|
|
|
|
|
Example:
|
|
|
|
select hash(x) from y;
|
|
|
|
|
|
|
|
|
|
|
|
----
|
|
|
|
LEFT
|
|
|
|
----
|
|
|
|
|
|
|
|
Function:
|
|
|
|
Returns the substring of a specified length that appears at the start of a string.
|
|
|
|
|
|
|
|
Format:
|
|
|
|
LEFT( <string>, <number> )
|
|
|
|
|
|
|
|
Example:
|
|
|
|
select left(name, char_length(name) - 10)
|
|
|
|
from people
|
|
|
|
where name like '% FERNANDES';
|
|
|
|
|
|
|
|
|
|
|
|
--
|
|
|
|
LN
|
|
|
|
--
|
|
|
|
|
|
|
|
Function:
|
|
|
|
Returns the natural logarithm of a number.
|
|
|
|
|
|
|
|
Format:
|
|
|
|
LN( <number> )
|
|
|
|
|
|
|
|
Example:
|
|
|
|
select ln(x) from y;
|
|
|
|
|
|
|
|
|
|
|
|
---
|
|
|
|
LOG
|
|
|
|
---
|
|
|
|
|
|
|
|
Function:
|
|
|
|
LOG(x, y) returns the logarithm base x of y.
|
|
|
|
|
|
|
|
Format:
|
|
|
|
LOG( <number>, <number> )
|
|
|
|
|
|
|
|
Example:
|
|
|
|
select log(x, 10) from y;
|
|
|
|
|
|
|
|
|
|
|
|
-----
|
|
|
|
LOG10
|
|
|
|
-----
|
|
|
|
|
|
|
|
Function:
|
|
|
|
Returns the logarithm base ten of a number.
|
|
|
|
|
|
|
|
Format:
|
|
|
|
LOG10( <number> )
|
|
|
|
|
|
|
|
Example:
|
|
|
|
select log10(x) from y;
|
|
|
|
|
|
|
|
|
|
|
|
----
|
|
|
|
LPAD
|
|
|
|
----
|
|
|
|
|
|
|
|
Function:
|
|
|
|
LPAD(string1, length, string2) appends string2 to the beginning of
|
|
|
|
string1 until length of the result string becomes equal to length.
|
|
|
|
|
|
|
|
Format:
|
|
|
|
LPAD( <string>, <number> [, <string> ] )
|
|
|
|
|
|
|
|
Notes:
|
|
|
|
1) If the second string is omitted the default value is one space.
|
|
|
|
2) The second string is truncated when the result string will
|
|
|
|
become larger than length.
|
|
|
|
|
|
|
|
Example:
|
|
|
|
select lpad(x, 10) from y;
|
|
|
|
|
|
|
|
|
|
|
|
--------
|
|
|
|
MAXVALUE
|
|
|
|
--------
|
|
|
|
|
|
|
|
Function:
|
|
|
|
Returns the maximum value of a list of values.
|
|
|
|
|
|
|
|
Format:
|
|
|
|
MAXVALUE( <value> [, <value> ...] )
|
|
|
|
|
|
|
|
Example:
|
|
|
|
select maxvalue(v1, v2, 10) from x;
|
|
|
|
|
|
|
|
|
|
|
|
--------
|
|
|
|
MINVALUE
|
|
|
|
--------
|
|
|
|
|
|
|
|
Function:
|
|
|
|
Returns the minimun value of a list of values.
|
|
|
|
|
|
|
|
Format:
|
|
|
|
MINVALUE( <value> [, <value> ...] )
|
|
|
|
|
|
|
|
Example:
|
|
|
|
select minvalue(v1, v2, 10) from x;
|
|
|
|
|
|
|
|
|
|
|
|
---
|
|
|
|
MOD
|
|
|
|
---
|
|
|
|
|
|
|
|
Function:
|
|
|
|
MOD(X, Y) returns the remainder part of the division of X by Y.
|
|
|
|
|
|
|
|
Format:
|
|
|
|
MOD( <number>, <number> )
|
|
|
|
|
|
|
|
Example:
|
|
|
|
select mod(x, 10) from y;
|
|
|
|
|
|
|
|
|
|
|
|
-------
|
|
|
|
OVERLAY
|
|
|
|
-------
|
|
|
|
|
|
|
|
Function:
|
|
|
|
OVERLAY( <string1> PLACING <string2> FROM <start> [ FOR <length> ] ) returns
|
|
|
|
string1 replacing the substring FROM start FOR length by string2.
|
|
|
|
|
|
|
|
Format:
|
|
|
|
OVERLAY( <string> PLACING <string> FROM <number> [ FOR <number> ] )
|
|
|
|
|
|
|
|
Notes:
|
|
|
|
1) If <length> is not specified, CHAR_LENGTH( <string2> ) is implied.
|
|
|
|
2) The OVERLAY function is equivalent to:
|
2008-10-03 07:41:16 +02:00
|
|
|
SUBSTRING(<string1> FROM 1 FOR <start> - 1) ||
|
2007-04-15 03:11:35 +02:00
|
|
|
<string2> ||
|
2008-10-03 07:41:16 +02:00
|
|
|
SUBSTRING(<string1> FROM <start> + <length>)
|
2007-04-15 03:11:35 +02:00
|
|
|
|
|
|
|
|
|
|
|
--
|
|
|
|
PI
|
|
|
|
--
|
|
|
|
|
|
|
|
Function:
|
|
|
|
Returns the PI constant (3.1459...).
|
|
|
|
|
|
|
|
Format:
|
|
|
|
PI()
|
|
|
|
|
|
|
|
Example:
|
|
|
|
val = PI();
|
|
|
|
|
|
|
|
|
|
|
|
--------
|
|
|
|
POSITION
|
|
|
|
--------
|
|
|
|
|
|
|
|
Function:
|
2007-11-12 01:31:11 +01:00
|
|
|
Returns the position of the first string inside the second string starting at
|
|
|
|
an offset (or from the beginning when omitted).
|
2007-04-15 03:11:35 +02:00
|
|
|
|
|
|
|
Format:
|
2007-11-12 01:31:11 +01:00
|
|
|
POSITION( <string> IN <string> )
|
|
|
|
POSITION( <string>, <string> [, <number>] )
|
2007-04-15 03:11:35 +02:00
|
|
|
|
|
|
|
Example:
|
|
|
|
select rdb$relation_name
|
|
|
|
from rdb$relations
|
|
|
|
where position('RDB$' IN rdb$relation_name) = 1;
|
|
|
|
|
|
|
|
|
|
|
|
-----
|
|
|
|
POWER
|
|
|
|
-----
|
|
|
|
|
|
|
|
Function:
|
|
|
|
POWER(X, Y) returns X to the power of Y.
|
|
|
|
|
|
|
|
Format:
|
|
|
|
POWER( <number>, <number> )
|
|
|
|
|
|
|
|
Example:
|
|
|
|
select power(x, 10) from y;
|
|
|
|
|
|
|
|
|
|
|
|
----
|
|
|
|
RAND
|
|
|
|
----
|
|
|
|
|
|
|
|
Function:
|
|
|
|
Returns a random number between 0 and 1.
|
|
|
|
|
|
|
|
Format:
|
|
|
|
RAND()
|
|
|
|
|
|
|
|
Example:
|
|
|
|
select * from x order by rand();
|
|
|
|
|
|
|
|
|
|
|
|
-------
|
|
|
|
REPLACE
|
|
|
|
-------
|
|
|
|
|
|
|
|
Function:
|
|
|
|
REPLACE(searched, find, replacement) replaces all occurences of "find"
|
|
|
|
in "searched" by "replacement".
|
|
|
|
|
|
|
|
Format:
|
|
|
|
REPLACE( <string>, <string>, <string> )
|
|
|
|
|
|
|
|
Example:
|
|
|
|
select replace(x, ' ', ',') from y;
|
|
|
|
|
|
|
|
|
|
|
|
-------
|
|
|
|
REVERSE
|
|
|
|
-------
|
|
|
|
|
|
|
|
Function:
|
|
|
|
Returns a string in reverse order.
|
|
|
|
|
|
|
|
Format:
|
|
|
|
REVERSE( <value> )
|
|
|
|
|
|
|
|
Notes:
|
|
|
|
REVERSE is an useful function to index strings from right to left.
|
|
|
|
|
|
|
|
Example:
|
|
|
|
create index people_email on people computed by (reverse(email));
|
|
|
|
select * from people where reverse(email) starting with reverse('.br');
|
|
|
|
|
|
|
|
|
|
|
|
-----
|
|
|
|
RIGHT
|
|
|
|
-----
|
|
|
|
|
|
|
|
Function:
|
2008-10-03 07:41:16 +02:00
|
|
|
RIGHT(string, length)
|
2007-04-15 03:11:35 +02:00
|
|
|
Returns the substring of a specified length that appears at the end of a string.
|
|
|
|
|
|
|
|
Format:
|
|
|
|
RIGHT( <string>, <number> )
|
|
|
|
|
|
|
|
Example:
|
|
|
|
select right(rdb$relation_name, char_length(rdb$relation_name) - 4)
|
|
|
|
from rdb$relations
|
|
|
|
where rdb$relation_name like 'RDB$%';
|
|
|
|
|
|
|
|
|
|
|
|
-----
|
|
|
|
ROUND
|
|
|
|
-----
|
|
|
|
|
|
|
|
Function:
|
2008-10-03 07:41:16 +02:00
|
|
|
ROUND(number, scale)
|
2007-04-15 03:11:35 +02:00
|
|
|
Returns a number rounded to the specified scale.
|
|
|
|
|
|
|
|
Format:
|
2007-11-12 01:02:18 +01:00
|
|
|
ROUND( <number> [, <number> ] )
|
2007-04-15 03:11:35 +02:00
|
|
|
|
2007-04-21 23:27:22 +02:00
|
|
|
Notes:
|
|
|
|
If the scale (second parameter) is negative, the integer part of
|
|
|
|
the value is rounded. Ex: ROUND(123.456, -1) returns 120.000.
|
|
|
|
|
2007-04-15 03:11:35 +02:00
|
|
|
Examples:
|
|
|
|
select round(salary * 1.1, 0) from people;
|
|
|
|
|
|
|
|
|
|
|
|
----
|
|
|
|
RPAD
|
|
|
|
----
|
|
|
|
|
|
|
|
Function:
|
|
|
|
RPAD(string1, length, string2) appends string2 to the end of
|
|
|
|
string1 until length of the result string becomes equal to length.
|
|
|
|
|
|
|
|
Format:
|
|
|
|
RPAD( <string>, <number> [, <string> ] )
|
|
|
|
|
|
|
|
Notes:
|
|
|
|
1) If the second string is omitted the default value is one space.
|
|
|
|
2) The second string is truncated when the result string will
|
|
|
|
become larger than length.
|
|
|
|
|
|
|
|
Example:
|
|
|
|
select rpad(x, 10) from y;
|
|
|
|
|
|
|
|
|
|
|
|
----
|
|
|
|
SIGN
|
|
|
|
----
|
|
|
|
|
|
|
|
Function:
|
|
|
|
Returns 1, 0, or -1 depending on whether the input value is positive, zero or
|
|
|
|
negative, respectively.
|
|
|
|
|
|
|
|
Format:
|
|
|
|
SIGN( <number> )
|
|
|
|
|
|
|
|
Example:
|
|
|
|
select sign(x) from y;
|
|
|
|
|
|
|
|
|
|
|
|
---
|
|
|
|
SIN
|
|
|
|
---
|
|
|
|
|
|
|
|
Function:
|
2008-04-25 13:00:55 +02:00
|
|
|
Returns the sine of an angle (expressed in radians).
|
2007-04-15 03:11:35 +02:00
|
|
|
|
|
|
|
Format:
|
|
|
|
SIN( <number> )
|
|
|
|
|
|
|
|
Notes:
|
|
|
|
Argument to SIN must be specified in radians.
|
|
|
|
|
|
|
|
Example:
|
|
|
|
select sin(x) from y;
|
|
|
|
|
|
|
|
|
|
|
|
----
|
|
|
|
SINH
|
|
|
|
----
|
|
|
|
|
|
|
|
Function:
|
2008-04-25 13:00:55 +02:00
|
|
|
Returns the hyperbolic sine of an angle (expressed in radians).
|
2007-04-15 03:11:35 +02:00
|
|
|
|
|
|
|
Format:
|
|
|
|
SINH( <number> )
|
|
|
|
|
|
|
|
Example:
|
|
|
|
select sinh(x) from y;
|
|
|
|
|
|
|
|
|
|
|
|
----
|
|
|
|
SQRT
|
|
|
|
----
|
|
|
|
|
|
|
|
Function:
|
|
|
|
Returns the square root of a number.
|
|
|
|
|
|
|
|
Format:
|
|
|
|
SQRT( <number> )
|
|
|
|
|
|
|
|
Example:
|
|
|
|
select sqrt(x) from y;
|
|
|
|
|
|
|
|
|
|
|
|
---
|
|
|
|
TAN
|
|
|
|
---
|
|
|
|
|
|
|
|
Function:
|
2008-04-25 13:00:55 +02:00
|
|
|
Returns the tangent of an angle (expressed in radians).
|
2007-04-15 03:11:35 +02:00
|
|
|
|
|
|
|
Format:
|
|
|
|
TAN( <number> )
|
|
|
|
|
|
|
|
Notes:
|
|
|
|
Argument to TAN must be specified in radians.
|
|
|
|
|
|
|
|
Example:
|
|
|
|
select tan(x) from y;
|
|
|
|
|
|
|
|
|
|
|
|
----
|
|
|
|
TANH
|
|
|
|
----
|
|
|
|
|
|
|
|
Function:
|
2008-04-25 13:00:55 +02:00
|
|
|
Returns the hyperbolic tangent of an angle (expressed in radians).
|
2007-04-15 03:11:35 +02:00
|
|
|
|
|
|
|
Format:
|
|
|
|
TANH( <number> )
|
|
|
|
|
|
|
|
Example:
|
|
|
|
select tanh(x) from y;
|
|
|
|
|
|
|
|
|
|
|
|
-----
|
|
|
|
TRUNC
|
|
|
|
-----
|
|
|
|
|
|
|
|
Function:
|
2008-10-03 07:41:16 +02:00
|
|
|
TRUNC(number, scale)
|
2007-07-03 02:09:39 +02:00
|
|
|
Returns the integral part (up to the specified scale) of a number.
|
2007-04-15 03:11:35 +02:00
|
|
|
|
|
|
|
Format:
|
2007-07-03 02:09:39 +02:00
|
|
|
TRUNC( <number> [, <number> ] )
|
|
|
|
|
|
|
|
Notes:
|
|
|
|
If the scale (second parameter) is negative, the integer part of
|
|
|
|
the value is truncated. Ex: TRUNC(123.456, -1) returns 120.000.
|
2007-04-15 03:11:35 +02:00
|
|
|
|
|
|
|
Example:
|
2007-04-21 23:27:22 +02:00
|
|
|
1) select trunc(x) from y;
|
2007-04-24 08:11:08 +02:00
|
|
|
2) select trunc(-2.8), trunc(2.8) from rdb$database; -- returns -2, 2
|
2007-07-03 02:09:39 +02:00
|
|
|
3) select trunc(987.65, 1), trunc(987.65, -1) from rdb$database; -- returns 987.60, 980.00
|
2008-05-09 17:27:31 +02:00
|
|
|
|
|
|
|
|
|
|
|
------------
|
|
|
|
UUID_TO_CHAR
|
|
|
|
------------
|
|
|
|
|
|
|
|
Function:
|
|
|
|
Converts a CHAR(16) OCTETS UUID (that's returned by GEN_UUID) to the
|
|
|
|
CHAR(32) ASCII representation (XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX).
|
|
|
|
|
|
|
|
Format:
|
|
|
|
UUID_TO_CHAR( <string> )
|
|
|
|
|
2012-07-10 18:00:27 +02:00
|
|
|
Important (for big-endian servers):
|
|
|
|
It has been discovered that before Firebird 2.5.2, CHAR_TO_UUID and UUID_TO_CHAR works
|
|
|
|
incorrectly in big-endian servers. In these machines, bytes/characters are swapped and goes in
|
|
|
|
wrong positions when converting. This bug was fixed in 2.5.2 and 3.0, but that means these
|
|
|
|
functions now returns different values (for the same input parameter) than before.
|
2011-12-21 15:45:39 +01:00
|
|
|
|
2008-05-09 17:27:31 +02:00
|
|
|
Example:
|
|
|
|
select uuid_to_char(gen_uuid()) from rdb$database;
|
|
|
|
|
2012-07-10 18:00:27 +02:00
|
|
|
See also: GEN_UUID and CHAR_TO_UUID
|