8
0
mirror of https://github.com/FirebirdSQL/firebird.git synced 2025-01-25 05:23:02 +01:00
firebird-mirror/doc/sql.extensions/README.builtin_functions.txt

1285 lines
30 KiB
Plaintext
Raw Normal View History

=================
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>
Alexander Peshkov <peshkoff@mail.ru>
---
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;
2013-04-13 07:58:54 +02:00
-----
ACOSH
-----
Function:
Returns the hyperbolic arc cosine of a number (expressed in radians).
Format:
ACOSH( <number> )
Example:
select acosh(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.
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;
2013-04-13 07:58:54 +02:00
-----
ASINH
-----
Function:
Returns the hyperbolic arc sine of a number (expressed in radians).
Format:
ASINH( <number> )
Example:
select asinh(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;
2013-04-13 07:58:54 +02:00
-----
ATANH
-----
Function:
Returns the hyperbolic arc tangent of a number (expressed in radians).
Format:
ATANH( <number> )
Example:
select atanh(x) from y;
-----------------------------
BASE64_ENCODE / BASE64_DECODE
-----------------------------
Function:
Encodes / decodes input data to / from BASE64 representation. Works with character strings and blobs.
Format:
BASE64_ENCODE( <binary data> )
BASE64_DECODE( <base64 data> )
Example:
select base64_encode(public_key) from clients;
-------
BIN_AND
-------
Function:
Returns the result of a binary AND operation performed on all arguments.
Format:
BIN_AND( <number>, <number> [, <number> ...] )
Example:
select bin_and(flags, 1) from x;
-------
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;
------
BIN_OR
------
Function:
Returns the result of a binary OR operation performed on all arguments.
Format:
BIN_OR( <number>, <number> [, <number> ...] )
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:
BIN_XOR( <number>, <number> [, <number> ...] )
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
------------
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> )
Important (for big-endian servers):
2012-07-29 02:24:00 +02:00
It has been discovered that before Firebird 2.5.2, CHAR_TO_UUID and UUID_TO_CHAR work
incorrectly in big-endian servers. In these machines, bytes/characters are swapped and go in
wrong positions when converting. This bug was fixed in 2.5.2 and 3.0, but that means these
2012-07-29 02:24:00 +02:00
functions now return different values (for the same input parameter) than before.
Example:
select char_to_uuid('93519227-8D50-4E47-81AA-8F6678C096A1') from rdb$database;
See also: GEN_UUID and UUID_TO_CHAR
---
COS
---
Function:
2008-04-25 13:00:55 +02:00
Returns the cosine of an angle (expressed in radians).
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).
Format:
COSH( <number> )
Example:
select cosh(x) from y;
---
COT
---
Function:
Returns 1 / tan(argument).
Format:
COT( <number> )
Example:
select cot(x) from y;
----------
CRYPT_HASH
----------
Function:
Returns a cryptograpic hash of an argument using a specified algorithm.
Format:
CRYPT_HASH( <any value> USING <algorithm> )
algorithm ::= { MD5 | SHA1 | SHA256 | SHA512 }
Important:
- This function returns VARCHAR strings with OCTETS charset with length depended on algorithm.
- MD5 and SHA1 algorithms are not recommended for use due to known severe issues, that algorithms
are provided ONLY for backward compatibility.
Example:
select crypt_hash(x using sha256) 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> )
2008-04-14 15:21:05 +02:00
timestamp_part ::= { YEAR | MONTH | DAY | WEEK | HOUR | MINUTE | SECOND | MILLISECOND }
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.
3) All timestamp_part values could be used with timestamp values.
2016-11-04 15:22:46 +01: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).
2016-11-04 15:22:46 +01:00
5) When using YEAR or MONTH and the input day is greater than the maximum possible day in the
result year/month, the result day is returned in the last day of the result year/month.
2008-04-12 14:43:58 +02:00
Example:
select dateadd(-1 day to current_date) as yesterday
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.
Format:
DATEDIFF( <timestamp_part> FROM <date_time> TO <date_time> )
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
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.
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;
------
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;
-------------------
ENCRYPT and DECRYPT
-------------------
Function:
Encrypts/decrypts data using symmetric cipher.
Format:
2018-12-15 21:44:59 +01:00
{ENCRYPT | DECRYPT} ( <string | blob> USING <algorithm> [MODE <mode>] KEY <string>
[IV <string>] [<endianness>] [CTR_LENGTH <smallint>] [COUNTER <bigint>])
algorithm ::= { block_cipher | stream_cipher }
block_cipher ::= { AES | ANUBIS | BLOWFISH | KHAZAD | RC5 | RC6 | SAFER+ | TWOFISH | XTEA }
stream_cipher ::= { CHACHA20 | RC4 | SOBER128 }
mode ::= { CBC | CFB | CTR | ECB | OFB }
endianness ::= { CTR_BIG_ENDIAN | CTR_LITTLE_ENDIAN }
Important:
- Mode should be specified for block ciphers.
- Initialization vector (IV) should be specified for block ciphers in all modes except ECB and
all stream ciphers except RC4.
- Endianness may be specified only in CTR mode, default is little endian counter.
- Counter length (CTR_LENGTH, bytes) may be specified only in CTR mode, default is the size of IV.
- Initial counter value (COUNTER) may be specified only for CHACHA20 cipher, default is 0.
- Sizes of data strings passed to this functions are according to selected algorithm and mode
requirements.
- Functions return BLOB when first argument is blob and varbinary for all other types.
- Other parameters (except algorithm, mode and endianness) may have any type provided that data size
is appropriate for selected algorithm and mode.
Example:
select encrypt('897897' using sober128 key 'AbcdAbcdAbcdAbcd' iv '01234567') from rdb$database;
2021-05-13 13:11:04 +02:00
select cast(decrypt(x'0154090759DF' using sober128 key 'AbcdAbcdAbcdAbcd' iv '01234567') as varchar(128)) from rdb$database;
select decrypt(secret_field using aes mode ofb key '0123456701234567' iv init_vector) from secure_table;
---
EXP
---
Function:
Returns the exponential e to the argument.
Format:
EXP( <number> )
Example:
select exp(x) from y;
---------
FIRST_DAY
---------
Function:
2017-11-06 01:22:00 +01:00
Returns a date/timestamp with the first day of the year/month/week of a given
date/timestamp value.
Format:
FIRST_DAY( OF { YEAR | MONTH | WEEK } FROM <date_or_timestamp> )
Notes:
1) The first day of the week is considered as Sunday, per the same rules of EXTRACT with WEEKDAY.
2) When a timestamp is passed the return value preserves the time part.
Example:
select first_day(of month from current_date) from rdb$database;
select first_day(of year from current_timestamp) from rdb$database;
select first_day(of week from date '2017-11-01') from rdb$database;
-----
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
--------
GEN_UUID
--------
Function:
2008-05-11 05:00:46 +02:00
Returns an universal unique number in CHAR(16) OCTETS type.
Format:
GEN_UUID()
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
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.
Example:
insert into records (id) value (gen_uuid());
See also: CHAR_TO_UUID and UUID_TO_CHAR
----
HASH
----
Function:
Returns a hash of an argument using a specified algorithm.
Format:
HASH( <any value> [ USING <algorithm> ] )
algorithm ::= { CRC32 }
Important:
- The syntax without USING is very discouraged and maintained for backward compatibility.
It returns a 64 bit integer and produces very bad hashes that easily result in collisions.
- The syntax with USING is introduced in FB 4.0 and returns an integer of appropriate size.
- Implemented in firebird CRC32 is using polynomial 0x04C11DB7.
Example:
select hash(x) from y;
select hash(x using crc32) from y;
2019-04-17 12:15:30 +02:00
-----------------------------
HEX_ENCODE / HEX_DECODE
-----------------------------
Function:
Encodes / decodes input data to / from hexadecimal representation. Works with character strings and blobs.
Format:
HEX_ENCODE( <binary data> )
HEX_DECODE( <hex data> )
Example:
select hex_encode(public_key) from clients;
--------
LAST_DAY
--------
Function:
2017-11-06 01:22:00 +01:00
Returns a date/timestamp with the last day of the year/month/week of a given
date/timestamp value.
Format:
LAST_DAY( OF { YEAR | MONTH | WEEK } FROM <date_or_timestamp> )
Notes:
1) The last day of the week is considered as Saturday, per the same rules of EXTRACT with WEEKDAY.
2) When a timestamp is passed the return value preserves the time part.
Example:
select last_day(of month from current_date) from rdb$database;
select last_day(of year from current_timestamp) from rdb$database;
select last_day(of week from date '2017-11-01') from rdb$database;
----
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.
2010-06-18 15:13:37 +02:00
3) The first string is truncated if its length is greater than the length
parameter.
Example:
select lpad(x, 10) from y;
----------
MAKE_DBKEY
----------
Function:
MAKE_DBKEY( relation, recnum [, dpnum [, ppnum]] )
Creates DBKEY value using relation name or ID, record number, and, optionally,
logical number of data page and pointer page.
Format:
MAKE_DBKEY( <value>, <number> [, <number> [, <number>]] )
Notes:
1) If the first argument (relation) is a string expression or literal, then
it's treated as a relation name and the engine searches for the
corresponding relation ID. The search is case-sensitive.
In the case of string literal, relation ID is evaluated at prepare time.
In the case of expression, relation ID is evaluated at execution time.
If the relation couldn't be found, then isc_relnotdef error is raised.
2) If the first argument (relation) is a numeric expression or literal, then
it's treated as a relation ID and used "as is", without verification
against existing relations.
If the argument value is negative or greater than the maximum allowed
relation ID (65535 currently), then NULL is returned.
3) Second argument (recnum) represents an absolute record number in relation
(if the next arguments -- dpnum and ppnum -- are missing), or a record
number relative to the first record, specified by the next arguments.
4) Third argument (dpnum) is a logical number of data page in relation (if
the next argument -- ppnum -- is missing), or number of data page
relative to the first data page addressed by the given ppnum.
5) Forth argument (ppnum) is a logical number of pointer page in relation.
6) All numbers are zero-based.
Maximum allowed value for dpnum and ppnum is 2^32 (4294967296).
If dpnum is specified, then recnum could be negative.
If dpnum is missing and recnum is negative then NULL is returned.
If ppnum is specified, then dpnum could be negative.
If ppnum is missing and dpnum is negative then NULL is returned.
7) If any of specified arguments has NULL value, the result is also NULL.
8) First argument (relation) is described as INTEGER but could be overriden
by application as VARCHAR or CHAR.
recnum, dpnum and ppnum are described as BIGINT (64-bit signed integer).
Examples:
1) Select record using relation name (note, relation name is in uppercase)
select * from rdb$relations where rdb$db_key = make_dbkey('RDB$RELATIONS', 0)
2) Select record using relation ID
select * from rdb$relations where rdb$db_key = make_dbkey(6, 0)
3) Select all records that physically reside at first data page in relation
select * from rdb$relations
where rdb$db_key >= make_dbkey(6, 0, 0)
and rdb$db_key < make_dbkey(6, 0, 1)
4) Select all records that physically reside at first data page of 6th pointer
page at relation
select * from SOMETABLE
where rdb$db_key >= make_dbkey('SOMETABLE', 0, 0, 5)
and rdb$db_key < make_dbkey('SOMETABLE', 0, 1, 5)
--------
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:
SUBSTRING(<string1> FROM 1 FOR <start> - 1) ||
<string2> ||
SUBSTRING(<string1> FROM <start> + <length>)
--
PI
--
Function:
Returns the PI constant (3.1459...).
Format:
PI()
Example:
val = PI();
--------
POSITION
--------
Function:
Returns the position of the first string inside the second string starting at
an offset (or from the beginning when omitted). When not found, returns 0.
Format:
POSITION( <string> IN <string> )
POSITION( <string>, <string> [, <number>] )
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();
2019-01-05 21:47:04 +01:00
----------------------
RDB$GET_TRANSACTION_CN
2019-01-05 21:47:04 +01:00
----------------------
(FB4 extension)
Function:
Returns commit number of given transaction. Result type is BIGINT.
2018-12-15 21:44:59 +01:00
Note, engine internally uses unsigned 8-byte integer for commit numbers,
and unsigned 6-byte integer for transaction numbers. Thus, despite of
SQL language have no unsigned integers and RDB$GET_TRANSACTION_CN returns
2018-12-15 21:44:59 +01:00
signed BIGINT, it is impossible to see negative commit numbers except of
few special values used for non-committed transactions.
Summary, numbers returned by RDB$GET_TRANSACTION_CN could have values below:
-2 - transaction is dead (rolled back)
-1 - transaction is in limbo
0 - transaction is active,
2018-12-15 21:44:59 +01:00
1 - transaction committed before database started or less than database
2018-09-24 23:25:39 +02:00
Oldest Interesting Transaction
>1 - transaction committed after database started
NULL - given transaction number is NULL or greater than database Next Transaction
See also README.read_consistency.md
Format:
RDB$GET_TRANSACTION_CN( <transaction number> )
Examples:
select rdb$get_transaction_cn(current_transaction) from rdb$database;
select rdb$get_transaction_cn(123) from rdb$database;
2016-05-31 19:07:08 +02:00
--------------------
RDB$SYSTEM_PRIVILEGE
--------------------
(FB4 extension)
Function:
Returns true if current attachment has given system privilege.
Format:
RDB$SYSTEM_PRIVILEGE( <privilege> )
Example:
select rdb$system_privilege(user_management) from rdb$database;
-------
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:
RIGHT(string, length)
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:
ROUND(number, scale)
Returns a number rounded to the specified scale.
Format:
ROUND( <number> [, <number> ] )
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.
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.
2010-06-18 15:13:37 +02:00
3) The first string is truncated if its length is greater than the length
parameter.
Example:
select rpad(x, 10) from y;
-----------
RSA_PRIVATE
-----------
Function:
2018-12-07 18:20:28 +01:00
Returns RSA private key of specified length (in bytes) in PKCS#1 format as VARBINARY string.
Format:
RSA_PRIVATE ( <smallint> )
Example:
select rdb$set_context('USER_SESSION', 'private_key', rsa_private(256)) from rdb$database;
----------
RSA_PUBLIC
----------
Function:
Returns RSA public key for specified RSA private key, all keys are in PKCS#1 format.
Format:
RSA_PUBLIC ( <private key> )
Example:
(tip - start running samples one by one from RSA_PRIVATE function)
select rdb$set_context('USER_SESSION', 'public_key',
rsa_public(rdb$get_context('USER_SESSION', 'private_key'))) from rdb$database;
-----------
RSA_ENCRYPT
-----------
Function:
Pads data using OAEP padding and encrypts using RSA public key. Normally used to encrypt
short symmetric keys which are then used in block ciphers to encrypt a message.
Format:
RSA_ENCRYPT ( <string> KEY <public key> [LPARAM <string>] [HASH <hash>] [PKCS_1_5] )
KEY should be a value, returhed by RSA_PUBLIC function.
LPARAM is an additional system specific tag that can be applied to identify which
system encoded the message. Default value is NULL.
hash ::= { MD5 | SHA1 | SHA256 | SHA512 } Default is SHA256.
PKCS_1_5 makes engine use old padding, needed for backward compatibility.
Due to security reasons should NOT be used in new projects.
Example:
(tip - start running samples one by one from RSA_PRIVATE function)
select rdb$set_context('USER_SESSION', 'msg', rsa_encrypt('Some message'
key rdb$get_context('USER_SESSION', 'public_key'))) from rdb$database;
-----------
RSA_DECRYPT
-----------
Function:
Decrypts using RSA private key and OAEP de-pads the resulting data.
Format:
RSA_DECRYPT ( <string> KEY <private key> [LPARAM <string>] [HASH <hash>] [PKCS_1_5] )
KEY should be a value, returhed by RSA_PRIVATE function.
LPARAM is the same variable passed to RSA_ENCRYPT. If it does not match
what was used during encoding this function will not decrypt the packet.
2018-12-15 21:44:59 +01:00
hash ::= { MD5 | SHA1 | SHA256 | SHA512 } Default is SHA256.
PKCS_1_5 makes engine use old padding, needed for backward compatibility.
Due to security reasons should NOT be used in new projects.
Example:
(tip - start running samples one by one from RSA_PRIVATE function)
2021-05-13 13:11:04 +02:00
select cast(rsa_decrypt(rdb$get_context('USER_SESSION', 'msg')
key rdb$get_context('USER_SESSION', 'private_key')) as varchar(128)) from rdb$database;
-------------
RSA_SIGN_HASH
-------------
Function:
Performs PSS encoding of message digest to be signed and signs using RSA private key.
Format:
RSA_SIGN_HASH ( <string> KEY <private key> [HASH <hash>] [SALT_LENGTH <smallint>] [PKCS_1_5] )
KEY should be a value, returhed by RSA_PRIVATE function.
hash ::= { MD5 | SHA1 | SHA256 | SHA512 } Default is SHA256.
SALT_LENGTH indicates the length of the desired salt, and should typically be small.
A good value is between 8 and 16.
PKCS_1_5 makes engine use old padding, needed for backward compatibility.
Example:
(tip - start running samples one by one from RSA_PRIVATE function)
select rdb$set_context('USER_SESSION', 'msg', rsa_sign_hash(crypt_hash('Test message' using sha256)
key rdb$get_context('USER_SESSION', 'private_key'))) from rdb$database;
---------------
RSA_VERIFY_HASH
---------------
Function:
Performs PSS encoding of message digest to be signed and verifies it's digital signature
using RSA public key.
Format:
RSA_VERIFY_HASH ( <string> SIGNATURE <string> KEY <public key> [HASH <hash>] [SALT_LENGTH <smallint>] [PKCS_1_5] )
SIGNATURE should be a value, returhed by RSA_SIGN function.
KEY should be a value, returhed by RSA_PUBLIC function.
hash ::= { MD5 | SHA1 | SHA256 | SHA512 } Default is SHA256.
SALT_LENGTH indicates the length of the desired salt, and should typically be small.
A good value is between 8 and 16.
PKCS_1_5 makes engine use old padding, needed for backward compatibility.
Example:
(tip - start running samples one by one from RSA_PRIVATE function)
select rsa_verify_hash(crypt_hash('Test message' using sha256) signature rdb$get_context('USER_SESSION', 'msg')
key rdb$get_context('USER_SESSION', 'public_key')) from rdb$database;
----
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).
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).
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).
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).
Format:
TANH( <number> )
Example:
select tanh(x) from y;
-----
TRUNC
-----
Function:
TRUNC(number, scale)
Returns the integral part (up to the specified scale) of a number.
Format:
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.
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
3) select trunc(987.65, 1), trunc(987.65, -1) from rdb$database; -- returns 987.60, 980.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> )
Important (for big-endian servers):
2012-07-29 02:24:00 +02:00
It has been discovered that before Firebird 2.5.2, CHAR_TO_UUID and UUID_TO_CHAR work
incorrectly in big-endian servers. In these machines, bytes/characters are swapped and go in
wrong positions when converting. This bug was fixed in 2.5.2 and 3.0, but that means these
2012-07-29 02:24:00 +02:00
functions now return different values (for the same input parameter) than before.
Example:
select uuid_to_char(gen_uuid()) from rdb$database;
See also: GEN_UUID and CHAR_TO_UUID