Fonctions pour traiter les variables contextuelles
Fonctions pour travailler avec des chaînes de caractères
Fonctions pour travailler avec la date et l'heure
Fonctions permettant de travailler avec le type BLOB
Fonctions permettant de travailler avec le type DECFLOAT
Fonctions de conversion de type
Fonctions d'opérations binaires
Fonctions pour traiter les UUID
COALESCE()
DSQL, PSQL
COALESCE (<exp1>, <exp2> [, <expN> ... ])
Paramètre | Description |
---|---|
exp1, exp2 … expN |
Expressions de tout type compatible. |
dépend des types d’arguments d’entrée
La fonction COALESCE
prend deux arguments ou plus et retourne la valeur du premier argument non NULL
. Si tous les arguments sont NULL
, le résultat est également NULL
.
COALESCE
Cet exemple tente d’utiliser toutes les données disponibles pour composer un nom complet. Le champ NICKNAME
de la table PERSONS
est sélectionné. S’il est NULL
, la valeur du champ FIRSTNAME
est prise. S’il est également NULL
, la chaîne de caractères "Mr./Mrs.`" est utilisée. Ensuite le nom de famille (le champ `LASTNAME
) est ajouté à la valeur de la fonction COALESCE
. Notez que ce schéma ne fonctionne correctement que si les champs à sélectionner sont NULL
ou non vides : si l’un d’eux est une chaîne vide, c’est ce qui sera renvoyé comme valeur de la fonction COALESCE
.
SELECT
COALESCE(PE.NICKNAME, PE.FIRSTNAME, 'Mr./Mrs.') ||
' ' || PE.LASTNAME AS FULLNAME
FROM PERSONS PE
Dans cet exemple, si la requête renvoie NULL
lors du calcul de la somme, elle renverra 0
.
SELECT coalesce (sum (q), 0)
FROM bills
WHERE ...
CASE
.
DECODE()
DSQL, PSQL
DECODE(<testexpr>, <expr1>, <result1> [<expr2>, <result2> …] [, <defaultresult>])
construction équivalente CASE
CASE <testexpr> WHEN <expr1> THEN <result1> [WHEN <expr2> THEN <result2> …] [ELSE <defaultresult>] END
Paramètre | Description |
---|---|
testexpr |
Expressions de tout type compatible qui sont comparées à des expressions |
expr1, expr2, … exprN |
Expressions de tout type compatible par rapport à l’expression |
result1, result2, … resultN |
Retourne des expressions de n’importe quel type. |
defaultresult |
Une expression renvoyée si aucune des conditions n’a été remplie. |
dépend des types d’arguments d’entrée
Cette fonction est équivalente à la construction Simple CASE
, dans laquelle une expression donnée est comparée à d’autres expressions avant qu’une correspondance soit trouvée.Le résultat est la valeur donnée après l’expression avec laquelle la correspondance est trouvée.Si aucune correspondance n’est trouvée, la valeur par défaut est retournée (si elle est, bien sûr, donnée — sinon NULL
est retourné).
Caution
|
Une correspondance est équivalente à l’opérateur ‘ |
DECODE
DECODE
select name,
age,
decode(upper(sex),
'M', 'Male',
'F', 'Female',
'Unknown'),
religion
from people
CASE
.
IIF()
DSQL, PSQL
IIF (<condition>, ResultT, ResultF)
Paramètre | Description |
---|---|
condition |
Une expression du type logique. |
resultT |
Valeur de retour si condition est vraie. |
resultF |
Valeur de retour si condition est fausse. |
dépend des types d’arguments d’entrée
La fonction IIF
a trois arguments. Si le premier argument est vrai, le résultat est le deuxième paramètre, sinon le résultat est le troisième paramètre.
L’opérateur IIF
peut également être comparé à l’opérateur triple “?:
” dans les langages C-like.
Note
|
Essentiellement, la fonction CASE WHEN <condition> THEN resultT ELSE resultF END |
IIF
IIF
SELECT IIF(SEX = 'M', 'Sir', 'Madam') FROM CUSTOMERS
CASE
.
MAXVALUE()
DSQL, PSQL
MAXVALUE (<expr1> [, ... , <exprN> ])
Paramètre | Description |
---|---|
expr1 … exprN |
Expressions de tout type compatible. |
est le même que le premier argument de expr1.
Renvoie la valeur maximale d’une liste de nombres, de chaînes de caractères ou de paramètres de type DATE
/ TIME
/ TIMESTAMP
.
Note
|
Si un ou plusieurs paramètres d’entrée sont |
MAXVALUE
MAXVALUE
SELECT MAXVALUE(PRICE_1, PRICE_2) AS PRICE
FROM PRICELIST
MINVALUE()
DSQL, PSQL
MINVALUE (<expr1> [, ... , <exprN> ])
Paramètre | Description |
---|---|
expr1 … exprN |
Expressions de tout type compatible. |
est le même que le premier argument de expr1.
Renvoie la valeur minimale d’une liste de nombres, de chaînes de caractères ou de paramètres de type DATE
/ TIME
/ TIMESTAMP
.
Note
|
Si un ou plusieurs paramètres d’entrée sont |
MINVALUE
MINVALUE
SELECT MINVALUE(PRICE_1, PRICE_2) AS PRICE
FROM PRICELIST
NULLIF()
DSQL, PSQL
NULLIF (<exp1>, <exp2>)
Paramètre | Description |
---|---|
expr1, expr2 |
Expressions de tout type compatible. |
dépend des types d’arguments d’entrée
La fonction retourne la valeur du premier argument s’il n’est pas égal au second. Si les arguments sont égaux, NULL
est retourné.
NULLIF
NULLIF
SELECT AVG(NULLIF(weight, -1)) FROM cargo;
Cette requête renvoie la valeur moyenne du champ weight
sur la table, sauf pour les lignes où il n’est pas spécifié (égal à -1). S’il n’y avait pas cette fonction, le simple opérateur avg(weight)
renverrait une valeur incorrecte.
Cette section contient des caractéristiques difficiles à catégoriser.
MAKE_DBKEY()
DSQL, PSQL
MAKE_DBKEY (<relation>, recnum [, dpnum [, ppnum]]}) <relation> ::= rel_name | rel_id
Paramètre | Description |
---|---|
rel_name |
Nom de la table. |
rel_id |
ID de la table. Peut être trouvé dans `RDB$RELATIONS.RDB$RELATION_ID'. |
recnum |
Numéro d’enregistrement, soit absolu (si dpnum et ppnum sont absents), soit relatif (si dpnum est présent). |
dpnum |
Numéro de page des données DP, soit absolu (si ppnum est absent), soit relatif (si ppnum est présent). |
ppnum |
Numéro de page des pointeurs vers les données PP. |
La fonction MAKE_DBKEY
crée une valeur DBKEY
en utilisant le nom ou l’identifiant de la table, le numéro d’enregistrement et, en option, un numéro de page de données logique et un numéro de page de pointeur.
Note
|
Remarques
|
La requête sélectionne un enregistrement en utilisant le nom de la table (nom de la table en majuscules).
select * from rdb$relations where rdb$db_key = make_dbkey('RDB$RELATIONS', 0)
La requête sélectionne un enregistrement en utilisant l’identifiant de la table
select * from rdb$relations where rdb$db_key = make_dbkey(6, 0)
La requête sélectionne tous les enregistrements qui sont physiquement sur la première page des données dans la table
select * from rdb$relations
where rdb$db_key >= make_dbkey(6, 0, 0)
and rdb$db_key < make_dbkey(6, 0, 1)
La requête sélectionne tous les enregistrements qui sont physiquement sur la première page de données de la page d’index 6 dans la table
select * from SOMETABLE
where rdb$db_key >= make_dbkey('SOMETABLE', 0, 0, 5)
and rdb$db_key < make_dbkey('SOMETABLE', 0, 1, 5)
Voir aussi: [fblangref-appx-supp-rdb-dbkey].
RDB$ERROR()
PSQL
RDB$ERROR (<context>) <context> ::= GDSCODE | SQLCODE | SQLSTATE | EXCEPTION | MESSAGE
Cela dépend du contexte
Renvoie la valeur du contexte de l’exception active. Le type de retour dépend du contexte.
Note
|
La fonction |
Contextes disponibles comme argument de la fonction RDB$ERROR
:
EXCEPTION
La fonction renvoie un nom d’exception si une exception définie par l’utilisateur est active, ou NULL
si une des exceptions du système est active.Pour le contexte EXCEPTION
, le type de valeur de retour : VARCHAR(63) JEU DE CARACTÈRES UTF8
.
MESSAGE
la fonction retourne le texte interprété d’une exception active.Pour le contexte MESSAGE
, le type de valeur de retour : VARCHAR(1024) JEU DE CARACTÈRES UTF8
.
GDSCODE
la fonction retourne la valeur de la variable contextuelle GDSCODE
.
SQLCODE
la fonction retourne la valeur de la variable contextuelle SQLCODE
.
SQLSTATE
la fonction retourne la valeur de la variable de contexte SQLSTATE
.
RDB$ERROR
pour sauvegarder le texte de l’erreur dans le journal de bord...
BEGIN
...
WHEN ANY DO
EXECUTE PROCEDURE P_LOG_EXCEPTION(RDB$ERROR(MESSAGE));
END
...
RDB$GET_TRANSACTION_CN()
DSQL, PSQL
RDB$GET_TRANSACTION_CN (transaction_id)
Paramètre | Description |
---|---|
transaction_id |
Numéro de transaction (identifiant) |
BIGINT
Renvoie le numéro d’engagement pour une transaction donnée.
Note
|
Les mécanismes internes de Firebird utilisent un entier non signé de 8 octets pour le Commit Number et un entier non signé de 6 octets pour le numéro de transaction. Par conséquent, même si le langage SQL n’a pas d’entiers non signés, et que |
Si la fonction RDB$GET_TRANSACTION_CN
renvoie une valeur supérieure à 1, il s’agit du (Commit Number) réel de la transaction, c’est-à-dire que la transaction a été validée après le démarrage de la base de données.
Dans d’autres cas, la fonction peut renvoyer l’un des résultats suivants indiquant l’état de validation de la transaction :
-2
|
transactions mortes (annulées) ; |
-1
|
Transactions suspendues (en état de limbo 2PC transactions) ; |
0
|
transactions actives ; |
1
|
pour les transactions validées avant le démarrage de la base de données ou avec un numéro inférieur à OIT (Oldest Interesting Transaction) ; |
NULL
|
: Si le numéro de transaction est |
RDB$GET_TRANSACTION_CN
select rdb$get_transaction_cn(current_transaction) from rdb$database;
select rdb$get_transaction_cn(123) from rdb$database;
Retourne le numéro de commit de la transaction donnée. Le type de résultat est BIGINT.
Note
|
Remarques :
le moteur utilise en interne des entiers non signés de 8 octets pour les numéros de commit, et des entiers non signés de 6 octets pour les numéros de transaction. Ainsi, malgré que le langage SQL n'ait pas d'entiers non signés et que RDB$GET_TRANSACTION_CN retourne BIGINT signés, il est impossible de voir des nombres de commit négatifs à l'exception des quelques valeurs spéciales utilisées pour les transactions non commises. En résumé, les nombres retournés par RDB$GET_TRANSACTION_CN peuvent avoir les valeurs suivantes : -2 - la transaction est morte (annulée) -1 - la transaction est dans les limbes 0 - la transaction est active, 1 - la transaction a été effectuée avant le démarrage de la base de données ou moins que la base de données. Transaction intéressante la plus ancienne >1 - transaction effectuée après le démarrage de la base de données NULL - le numéro de transaction donné est NULL ou supérieur à celui de la base de données Next Transaction (Transaction suivante) |
Voir aussi README.read_consistency.md
Format : RDB$GET_TRANSACTION_CN( <numéro de transaction> )
Exemples :
select rdb$get_transaction_cn(current_transaction) from rdb$database ;
select rdb$get_transaction_cn(123) from rdb$database ;
Note
|
Pour plus d’informations sur le Commit Number, reportez-vous aux Firebird 4.0 Release Notes. |
RDB$ROLE_IN_USE()
DSQL, PSQL
RDB$ROLE_IN_USE (role_name)
Paramètre | Description |
---|---|
role_name |
Le nom du rôle dont l’utilisation est contrôlée. |
BOOLEAN
La fonction RDB$ROLE_IN_USE
retourne si le rôle est utilisé par l’utilisateur actuel.
Note
|
Cette fonction vous permet de vérifier l’utilisation de n’importe quel rôle : ceux spécifiés explicitement (lors de la connexion ou modifiés à l’aide de l’instruction SET ROLE) et ceux attribués implicitement (rôles attribués à un utilisateur à l’aide de la clause DEFAULT). |
RDB$ROLE_IN_USE
-- Vérifier si l'attribut explicitement attribué ou
-- rôle de MANAGER obtenu implicitement
IF (RDB$ROLE_IN_USE('MANAGER')) THEN
BEGIN
...
END
SELECT * FROM RDB$ROLES WHERE RDB$ROLE_IN_USE(RDB$ROLE_NAME)
RDB$SYSTEM_PRIVILEGE()
DSQL, PSQL
RDB$SYSTEM_PRIVILEGE (<privilege>)
Paramètre | Description |
---|---|
privilege |
Privilège système vérifiable |
BOOLEAN
La fonction RDB$SYSTEM_PRIVILEGE
utilise le privilège système de la connexion actuelle. Pour obtenir une liste des privilèges système, consultez la rubrique CREATE ROLE.
RDB$SYSTEM_PRIVILEGE
SELECT RDB$SYSTEM_PRIVILEGE(USER_MANAGEMENT) FROM RDB$DATABASE;
ABS()
DSQL, PSQL
ABS (number)
Paramètre | Description |
---|---|
number |
Expression de type numérique |
est le même que l’argument d’entrée.
La fonction ABS
renvoie la valeur absolue (modulo) de l’argument.
COS()
DSQL, PSQL
COS (angle)
Paramètre | Description |
---|---|
angle |
Angle exprimé en radians. |
DOUBLE PRECISION
La fonction COS
renvoie le cosinus d’un angle. L’argument doit être donné en radians.
Tout résultat NOT NULL
se situe dans l’intervalle [-1, 1].
COSH()
DSQL, PSQL
COSH (number)
Paramètre | Description |
---|---|
number |
Expression est de type numérique. |
DOUBLE PRECISION
La fonction COSH
renvoie le cosinus hyperbolique de l’argument.
Tout résultat NOT NULL
se situe dans l’intervalle [1, +∞].
COT()
DSQL, PSQL
COT (angle)
Paramètre | Description |
---|---|
angle |
Angle exprimé en radians. |
DOUBLE PRECISION
La fonction COT
renvoie la cotangente de l’angle. L’argument doit être donné en radians.
EXP()
DSQL, PSQL
EXP (number)
Paramètre | Description |
---|---|
number |
Expression est de type numérique. |
DOUBLE PRECISION
La fonction EXP
retourne la valeur de l’exposant naturel, enombre
.
FLOOR()
DSQL, PSQL
FLOOR (number)
Paramètre | Description |
---|---|
number |
Expression est de type numérique. |
BIGINT
, INT128
, DECFLOAT
ou DOUBLE PRECISION
selon le type d’argument.
La fonction FLOOR
renvoie un entier inférieur ou égal à l’argument.
[fblangref-scalarfuncs-ceil], [fblangref-scalarfuncs-trunc].
LN()
DSQL, PSQL
LN (number)
Paramètre | Description |
---|---|
number |
Expression est de type numérique. |
DOUBLE PRECISION
La fonction LN
renvoie le logarithme naturel de l’argument.
Note
|
Si un argument négatif ou nul est passé, la fonction renvoie une erreur. |
LOG()
DSQL, PSQL
LOG (x, y)
Paramètre | Description |
---|---|
x |
Base. Expression de type numérique. |
y |
Expression est de type numérique. |
DOUBLE PRECISION
La fonction LOG
renvoie le logarithme de y (deuxième argument) sur la base de x (premier argument).
Particularités d’utilisation :
Si l’un des arguments est inférieur ou égal à 0, une erreur se produit ;
Si les deux arguments valent 1, le résultat de la fonction est NaN
(Not-a-Number — pas un nombre) ;
Si x = 1 et y < 1, le résultat de la fonction est -INF
(-∞) ;
Si x = 1 et y > 1, le résultat de la fonction est `INF` (∞).
LOG10()
DSQL, PSQL
LOG10 (number)
Paramètre | Description |
---|---|
number |
Expression est de type numérique. |
DOUBLE PRECISION
La fonction `LOG10' renvoie le logarithme décimal de l’argument.
Note
|
Si l’argument d’entrée est négatif ou égal à 0, une erreur se produit. |
MOD()
DSQL, PSQL
MOD (a, b)
Paramètre | Description |
---|---|
a |
Expression est de type numérique. |
b |
Expression est de type numérique. |
INTEGER
, BIGINT
ou INT128
selon les types d’arguments.
La fonction MOD
renvoie le reste d’une division d’un nombre entier.
Note
|
Les nombres réels sont arrondis avant d’effectuer la division. Par exemple, le résultat de “`mod(7,5, 2,5)`” serait 2 (" |
PI()
DSQL, PSQL
PI ()
DOUBLE PRECISION
La fonction PI
renvoie le nombre π.
ACOS()
DSQL, PSQL
ACOS (number)
Paramètre | Description |
---|---|
number |
Une expression de type numérique dans la plage [-1 ; 1]. |
DOUBLE PRECISION
La fonction ACOS
retourne l’arc cosinus (en radians) de l’argument.
Si l’argument de la fonction est en dehors de l’intervalle [-1, 1], la fonction renverra une valeur indéfinie NaN
.
POWER()
DSQL, PSQL
POWER (x, y)
Paramètre | Description |
---|---|
x |
Expression est de type numérique. |
y |
Expression est de type numérique. |
DOUBLE PRECISION
La fonction POWER
renvoie le résultat de l’élévation de x à la puissance de y, c’est-à-dire (xy).
Note
|
Si x est inférieur à zéro, une erreur se produit. |
RAND()
DSQL, PSQL
RAND ()
DOUBLE PRECISION
La fonction RAND
renvoie un nombre pseudo-aléatoire entre 0 et 1.
ROUND()
DSQL, PSQL
ROUND (number [, scale])
Paramètre | Description |
---|---|
number |
Expression est de type numérique. |
scale |
L’échelle est un nombre entier définissant le nombre de décimales auquel l’arrondi doit être effectué, soit
La valeur par défaut est 0. |
entier mis à l’échelle (INTEGER
, BIGINT
ou INT128
) ou DECFLOAT
ou DOUBLE PRECISION
selon le type de number.
La fonction ROUND
arrondit le nombre au nombre entier le plus proche. Si la partie fractionnaire est égale à 0,5, elle est arrondie au nombre entier supérieur le plus proche pour les nombres positifs et au nombre entier inférieur le plus proche pour les nombres négatifs. Avec le paramètre optionnel scale, le nombre peut être arrondi à l’une des puissances de 10 (dizaines, centaines, dixièmes, centièmes, etc.) au lieu d’un simple nombre entier.
Note
|
Si le paramètre scale est utilisé, le résultat a la même échelle que le premier paramètre number. |
ROUND
ROUND
ROUND(123.654, 1) -- Résultat : 123.700 (pas 123.7)
ROUND(8341.7, -3) -- Résultat : 8000.0 (pas 8000)
ROUND(45.1212, 0) -- Résultat : 45.0000 (pas 45)
ROUND(45.1212) -- Résultat : 45
SIGN()
DSQL, PSQL
SIGN (number)
Paramètre | Description |
---|---|
number |
Expression est de type numérique. |
SMALLINT
La fonction SIGN
renvoie le signe du paramètre d’entrée.
-1 — le nombre est inférieur à zéro
0 — le nombre est zéro
1 — le nombre est plus grand que zéro
SIN()
DSQL, PSQL
SIN (angle)
Paramètre | Description |
---|---|
angle |
Angle exprimé en radians. |
DOUBLE PRECISION
La fonction SIN
renvoie le sinus d’un angle. L’argument doit être donné en radians.
Tout résultat NOT NULL
se situe dans l’intervalle [-1, 1].
SINH()
DSQL, PSQL
SINH (number)
Paramètre | Description |
---|---|
number |
Expression est de type numérique. |
DOUBLE PRECISION
La fonction SINH
renvoie le sinus hyperbolique de l’argument.
SQRT()
DSQL, PSQL
SQRT (number)
Paramètre | Description |
---|---|
number |
Expression est de type numérique. |
DOUBLE PRECISION
La fonction SQRT
renvoie la racine carrée de l’argument.
TAN()
DSQL, PSQL
TAN (angle)
Paramètre | Description |
---|---|
angle |
Angle exprimé en radians. |
DOUBLE PRECISION
La fonction TAN
renvoie la tangente de l’angle. L’argument doit être donné en radians.
[fblangref-scalarfuncs-atan], [fblangref-scalarfuncs-atan2].
TANH()
DSQL, PSQL
TANH (number)
Paramètre | Description |
---|---|
number |
Expression est de type numérique. |
DOUBLE PRECISION
La fonction TANH
renvoie la tangente hyperbolique de l’argument.
Tout résultat NOT NULL
se situe dans l’intervalle [-1, 1].
TRUNC()
DSQL, PSQL
TRUNC (number [, scale])
Paramètre | Description |
---|---|
number |
Expression est de type numérique. |
scale |
L’échelle est un nombre entier définissant le nombre de décimales auquel la troncature doit être effectuée, c’est à dire
La valeur par défaut est 0. |
entier mis à l’échelle (INTEGER
, BIGINT
ou INT128
) ou DECFLOAT
ou DOUBLE PRECISION
selon le type de number.
La fonction TRUNC
tronque le nombre à l’entier le plus proche. Avec le paramètre optionnel scale, le nombre peut être tronqué à l’une des puissances de 10 (dizaines, centaines, dixièmes, centièmes, etc.) au lieu d’un simple nombre entier.
Note
|
Si le paramètre scale est utilisé, le résultat a la même échelle que le premier paramètre number. |
Important
|
La fonction incrémente toujours les nombres négatifs car elle rogne la partie fractionnaire. |
TRUNC
TRUNC(789.2225, 2) -- Résultat : 789.2200 (pas 789.22)
TRUNC(345.4, -2) -- Résultat : 300.0 (pas 300)
TRUNC(-163.41, 0) -- Résultat : -163.00 (pas -163)
TRUNC(-163.41) -- Résultat : -163
ACOSH()
DSQL, PSQL
ACOSH (number)
Paramètre | Description |
---|---|
number |
Une expression de type numérique dans la plage [1 ; +∞]. |
DOUBLE PRECISION
La fonction ACOSH
retourne l’arc cosinus hyperbolique (en radians) de l’argument.
ASIN()
DSQL, PSQL
ASIN (number)
Paramètre | Description |
---|---|
number |
Une expression de type numérique dans l’intervalle [-1 ; 1]. |
DOUBLE PRECISION
La fonction ASIN
renvoie l’arcsine (en radians) de l’argument.
Si l’argument de la fonction est en dehors de l’intervalle [-1, 1], la fonction renverra une valeur indéfinie NaN
.
ASINH()
DSQL, PSQL
ASIN (number)
Paramètre | Description |
---|---|
number |
Une expression de type numérique. |
DOUBLE PRECISION
La fonction ASINH
renvoie l’arcsinus hyperbolique (en radians) de l’argument.
ATAN()
DSQL, PSQL
ATAN (number)
Paramètre | Description |
---|---|
number |
Une expression de type numérique. |
DOUBLE PRECISION
La fonction ATAN
retourne l’arctangente de l’argument.
La fonction renvoie l’angle en radians dans l’intervalle [-π/2 ; π/2].
ATAN2()
DSQL, PSQL
ATAN2 (y, x)
Paramètre | Description |
---|---|
y |
Une expression de type numérique. |
x |
Une expression de type numérique. |
DOUBLE PRECISION
La fonction ATAN2
retourne l’angle comme le rapport du sinus au cosinus, avec les arguments donnés par ces deux paramètres, et les signes du sinus et du cosinus correspondant aux signes des paramètres.Cela permet d’obtenir des résultats pour le cercle entier, y compris pour les angles de -π/2 et π/2.
Caractéristiques d’utilisation :
Le résultat est un angle dans l’intervalle [-π, π] radians ;
Si x est négatif, le résultat est π lorsque y est nul et -π lorsqu’il est égal à 0 ;
Si y et x sont tous deux égaux à 0, le résultat n’a pas de sens.
Note
|
|
ATANH()
DSQL, PSQL
ATANH (number)
Paramètre | Description |
---|---|
number |
Une expression de type numérique. |
DOUBLE PRECISION
La fonction ATANH
retourne l’arctangente hyperbolique (en radians) de l’argument.
CEIL()
, CEILING()
DSQL, PSQL
CEIL[ING] (number)
Paramètre | Description |
---|---|
number |
Une expression de type numérique. |
BIGINT
, INT128
, DECFLOAT
ou DOUBLE PRECISION
selon le type d’argument.
La fonction CEIL
renvoie le plus petit entier supérieur ou égal à l’argument.
[fblangref-scalarfuncs-floor], [fblangref-scalarfuncs-trunc].
ASCII_CHAR()
DSQL, PSQL
ASCII_CHAR (code)
Paramètre | Description |
---|---|
code |
Un nombre entier compris entre 0 et 255. |
CHAR(1) CHARACTER SET NONE
.
La fonction ASCII_CHAR renvoie un caractère ASCII correspondant au nombre passé en argument.
LEFT()
DSQL, PSQL
LEFT (string, length)
Paramètre | Description |
---|---|
string |
Une expression de type chaîne de caractères. |
length |
Nombre entier. Spécifie le nombre de caractères retournés. |
VARCHAR
ou BLOB
.
La fonction LEFT
retourne le côté gauche de la chaîne de caractères, le nombre de caractères retournés est déterminé par le deuxième paramètre.
Caractéristiques d’utilisation :
La fonction prend en charge les blocs de texte de n’importe quelle longueur et avec n’importe quel jeu de caractères ;
Si l’argument chaîne est BLOB
, le résultat sera BLOB, sinon le résultat sera VARCHAR(N), avec N étant la longueur du paramètre chaîne ;
Si le paramètre numérique dépasse la longueur du texte, le résultat sera le texte original.
Warning
|
Lorsque vous utilisez |
SELECT LEFT('ABC', 2) FROM rdb$database;
-- Résultat AB
[fblangref-scalarfuncs-right], [fblangref-scalarfuncs-substring].
LOWER()
DSQL, PSQL, ESQL
LOWER (string)
Paramètre | Description |
---|---|
string |
Une expression de type chaîne de caractères. |
VAR[CHAR]
ou BLOB
La fonction LOWER
retourne la chaîne de caractères d’entrée en minuscules. Le résultat exact dépend du jeu de caractères de la chaîne d’entrée. Par exemple, pour les jeux de caractères NONE et ASCII, seuls les caractères ASCII sont convertis en minuscules ; pour les jeux de caractères OCTETS — la chaîne d’entrée entière est retournée inchangée.
LOWER
LOWER
select Sherifffrom Townswhere lower(Name) = 'cooper''s valley'
LPAD()
DSQL, PSQL
LPAD (str, endlen [, padstr])
Paramètre | Description |
---|---|
str |
Une expression de type chaîne de caractères. |
endlen |
La longueur de la chaîne de sortie. |
padstr |
Une chaîne de caractères qui est ajoutée à la chaîne de caractères d’origine jusqu’à la longueur spécifiée. (“ |
VARCHAR
ou BLOB
.
La fonction LPAD
étend la chaîne d’entrée vers la gauche avec des espaces ou une chaîne définie par l’utilisateur jusqu’à une longueur spécifiée.
Caractéristiques d’utilisation :
La fonction prend en charge les blocs de texte de n’importe quelle longueur et avec n’importe quel jeu de caractères ;
Si la chaîne d’entrée est de type BLOB
, le résultat sera également BLOB
, sinon le résultat sera VARCHAR(endlen)
.
Si l’argument padstr est donné mais est `
(chaîne vide), aucune chaîne n’est ajoutée ! Dans le cas où endlen est inférieur à la longueur de la chaîne d’entrée, le résultat est tronqué à la longueur de endlen, même si padstr est une chaîne vide.
Warning
|
Lorsque vous utilisez |
LPAD
LPAD
LPAD ('Hello', 12) -- renvoie ' Hello'
LPAD ('Hello', 12, '-') -- renvoie '-------Hello'
LPAD ('Hello', 12, '') -- renvoie 'Hello'
LPAD ('Hello', 12, 'abc') -- renvoie 'abcabcaHello'
LPAD ('Hello', 12, 'abcdefghij') -- renvoie 'abcdefgHello'
LPAD ('Hello', 2) -- renvoie 'He'
LPAD ('Hello', 2, '-') -- renvoie 'He'
LPAD ('Hello', 2, '') -- renvoie 'He'
OCTET_LENGTH()
DSQL, PSQL
OCTET_LENGTH (string)
Paramètre | Description |
---|---|
string |
Une expression de type chaîne de caractères. |
BIGINT
La fonction OCTET_LENGTH
renvoie le nombre d’octets occupés par la chaîne de caractères.
Lorsqu’il s’agit de paramètres de type CHAR
, la fonction renvoie la longueur totale de la chaîne formelle. Pour connaître la longueur logique
de la chaîne en octets, RIGHT TRIM doit être appliqué avant de passer l’argument à la fonction.
Note
|
Notez que tous les jeux de caractères n’ont pas le même nombre d’octets que le nombre de caractères. |
OCTET_LENGTH
OCTET_LENGTH
SELECT OCTET_LENGTH('Hello!')
FROM rdb$database
-- retournera 6
SELECT OCTET_LENGTH(_iso8859_1 'Grüß di!')
FROM rdb$database
-- retournera 8 : ü et ß n'occupent pas plus d'un octet en ISO8859_1
SELECT
OCTET_LENGTH(CAST(_iso8859_1 'Grüß di!' AS VARCHAR(24) CHARACTER SET utf8))
FROM rdb$database
-- retournera 10 : ü et ß occupent 2 octets en UTF8
SELECT
OCTET_LENGTH(CAST(_iso8859_1 'Grüß di!' AS CHAR(24) CHARACTER SET utf8))
FROM rdb$database
-- retournera 26 : un total de 24 positions CHAR et deux d'entre elles occupent 2 octets.
OVERLAY()
DSQL, PSQL
OVERLAY (string PLACING replacement FROM pos [FOR length])
Paramètre | Description |
---|---|
string |
La ligne dans laquelle le remplacement a lieu. |
replacement |
La ligne à remplacer par. |
pos |
La position à partir de laquelle le remplacement a lieu. |
length |
Le nombre de caractères à supprimer de la chaîne originale. |
VARCHAR
ou BLOB
La fonction OVERLAY
est utilisée pour remplacer une partie d’une chaîne de caractères par une autre chaîne.
Par défaut, le nombre de caractères à supprimer d’une chaîne est égal à la longueur de la chaîne à remplacer.Un quatrième paramètre facultatif permet à l’utilisateur de définir son propre nombre de caractères à supprimer.
Caractéristiques d’utilisation :
La fonction supporte entièrement le test BLOB
avec n’importe quel jeu de caractères et n’importe quelle longueur ;
Si la chaîne d’entrée est de type BLOB
, alors le résultat sera également de type BLOB
. Sinon, le type de résultat sera VARCHAR(n)
, où n est la somme des longueurs des paramètres string et replacement ;
Comme dans toutes les fonctions de chaîne SQL, pos est le paramètre déterminant ;
Si pos est plus long que la longueur de la chaîne, remplacement est placé immédiatement après la fin de la chaîne ;
Si le nombre de caractères entre pos et la fin de la chaîne est inférieur à la longueur de remplacement (ou au paramètre length, s’il est spécifié), la chaîne est tronquée à pos et remplacement est placé après elle ;
Si le paramètre length est égal à zéro (FOR 0), replacement est simplement inséré dans la chaîne, en commençant à la position pos ;
Si l’un des paramètres a la valeur NULL
, le résultat est NULL
;
Si les paramètres pos et length ne sont pas des entiers, l’arrondi bancaire (à un nombre pair) est utilisé : 0,5 devient 0, 1,5 devient 2, 2,5 devient 2, 3,5 devient 4, etc.
Warning
|
Lors de l’utilisation d’une fonction |
OVERLAY
OVERLAY
OVERLAY ('Goodbye' PLACING 'Hello' FROM 2) -- Résultat: 'GHelloe'
OVERLAY ('Goodbye' PLACING 'Hello' FROM 5) -- Résultat: 'GoodHello'
OVERLAY ('Goodbye' PLACING 'Hello' FROM 8) -- Résultat: 'GoodbyeHello'
OVERLAY ('Goodbye' PLACING 'Hello' FROM 20) -- Résultat: 'GoodbyeHello'
OVERLAY ('Goodbye' PLACING 'Hello' FROM 2 FOR 0) -– Résultat: 'GHellooodbye'
OVERLAY ('Goodbye' PLACING 'Hello' FROM 2 FOR 3) -- Résultat: 'GHellobye'
OVERLAY ('Goodbye' PLACING 'Hello' FROM 2 FOR 6) -- Résultat: 'GHello'
OVERLAY ('Goodbye' PLACING 'Hello' FROM 2 FOR 9) -- Résultat: 'Ghello'
OVERLAY ('Goodbye' PLACING '' FROM 4) -- Résultat: 'Goodbye'
OVERLAY ('Goodbye' PLACING '' FROM 4 FOR 3) -- Résultat: 'Gooe'
OVERLAY ('Goodbye' PLACING '' FROM 4 FOR 20) -- Résultat: 'Goo'
OVERLAY ('' PLACING 'Hello' FROM 4) -- Résultat: 'Hello'
OVERLAY ('' PLACING 'Hello' FROM 4 FOR 0) -- Résultat: 'Hello'
OVERLAY ('' PLACING 'Hello' FROM 4 FOR 20) -- Résultat: 'Hello'
[fblangref-scalarfuncs-substring], [fblangref-scalarfuncs-replace].
POSITION()
DSQL, PSQL
POSITION (substr IN string) | POSITION (substr, string [, startpos])
Paramètre | Description |
---|---|
substr |
Sous-chaîne dont la position est recherchée. |
string |
La ligne dans laquelle la position est recherchée. |
startpos |
La position à laquelle la recherche de sous-chaîne commence. |
INTEGER
La fonction POSITION
renvoie la position de la première occurrence d’une sous-chaîne dans la chaîne.Il commence par 1.Le troisième argument (facultatif) indique la position dans la chaîne à laquelle la recherche de la sous-chaîne commence, ignorant ainsi toutes les occurrences de la sous-chaîne dans la chaîne avant cette position.Si aucune correspondance n’est trouvée, la fonction renvoie 0.
Caractéristiques d’utilisation :
Un troisième paramètre facultatif n’est pris en charge que par la deuxième variante de la syntaxe (syntaxe à virgules séparées) ;
Une chaîne vide, la fonction la traite comme une sous-chaîne de n’importe quelle chaîne. Par conséquent, avec un paramètre d’entrée substr égal à '
(chaîne vide), et avec un paramètre string autre que NULL
, le résultat sera :
1, si le paramètre startpos n’est pas donné ;
startpos, si startpos ne dépasse pas la longueur du paramètre string ;
0 si startpos est supérieur à la longueur du paramètre string.
POSITION
POSITION
POSITION ('be' IN 'To be or not to be') -- Résultat: 4
POSITION ('be', 'To be or not to be') -- Résultat: 4
POSITION ('be', 'To be or not to be', 4) -- Résultat: 4
POSITION ('be', 'To be or not to be', 8) -- Résultat: 17
POSITION ('be', 'To be or not to be', 18) -- Résultat: 0
POSITION ('be' in 'Alas, poor Yorick!') -- Résultat: 0
REPLACE()
DSQL, PSQL
REPLACE (str, find, repl)
Paramètre | Description |
---|---|
str |
La ligne dans laquelle le remplacement est effectué. |
find |
La chaîne de caractères qui fait l’objet de la recherche. |
repl |
La ligne sur laquelle s’effectue le remplacement. |
VARCHAR
ou BLOB
La fonction REPLACE
remplace toutes les occurrences d’une chaîne par une autre.
Caractéristiques d’utilisation :
La fonction prend en charge les blocs de texte de n’importe quelle longueur et avec n’importe quel jeu de caractères ;
Si l’un des arguments est de type BLOB
, le résultat sera de type BLOB
. Sinon, le résultat sera de type VARCHAR(N)
, où N est calculé à partir des longueurs de str, find et repl de telle sorte que même le nombre maximal de substitutions ne provoquera pas de dépassement de champ.
Si le paramètre find est une chaîne vide, str est retourné inchangé ;
Si le paramètre repl est une chaîne vide, toutes les occurrences de find sont supprimées de la chaîne str ;
Si l’un des arguments est NULL
, le résultat est toujours NULL
, même si aucune substitution n’a été faite.
Warning
|
Lorsque vous utilisez |
REPLACE
REPLACE
REPLACE ('Billy Wilder', 'il', 'oog') -- retourne 'Boogly Woogder'
REPLACE ('Billy Wilder', 'il', '') -- retourne 'Bly Wder'
REPLACE ('Billy Wilder', null, 'oog') -- retourne NULL
REPLACE ('Billy Wilder', 'il', null) -- retourne NULL
REPLACE ('Billy Wilder', 'xyz', null) -- retourne NULL (!)
REPLACE ('Billy Wilder', 'xyz', 'abc') -- retourne 'Billy Wilder'
REPLACE ('Billy Wilder', '', 'abc') -- retourne 'Billy Wilder'
REVERSE()
DSQL, PSQL
REVERSE (string)
Paramètre | Description |
---|---|
string |
Une expression de type chaîne de caractères. |
VARCHAR
La fonction REVERSE
renvoie la chaîne de caractères inversée "à l’envers".
REVERSE
REVERSE
REVERSE ('spoonful') -- retourne 'lufnoops'
REVERSE ('Was it a cat I saw?') -- retourne '?was I tac a ti saW'
Tip
|
Cette fonction est très utile si vous souhaitez traiter (trier ou grouper) des informations qui se trouvent à la fin d’une chaîne de caractères, par exemple des noms de domaine ou des adresses électroniques.
|
RIGHT()
DSQL, PSQL
RIGHT (string, length)
Paramètre | Description |
---|---|
string |
Une expression de type chaîne de caractères. |
length |
Nombre entier. Spécifie le nombre de caractères retournés. |
VARCHAR
ou BLOB
La fonction RIGHT
renvoie la partie finale (droite) de la chaîne de caractères d’entrée.La longueur de la sous-chaîne retournée est déterminée par le deuxième paramètre.
Caractéristiques d’utilisation :
La fonction prend en charge les blocs de texte de n’importe quelle longueur et avec n’importe quel jeu de caractères ;
Si l’argument chaîne est BLOB
, le résultat est BLOB
, sinon le résultat est VARCHAR(N)
, avec N — égal à la longueur du paramètre chaîne ;
Si le paramètre numérique dépasse la longueur du texte, le résultat sera le texte original.
Warning
|
Lorsque vous utilisez |
RIGHT
SELECT RIGHT('ABC', 1) FROM rdb$database;
-- Résultat C
[fblangref-scalarfuncs-left], [fblangref-scalarfuncs-substring].
RPAD()
DSQL, PSQL
RPAD (str, endlen [, padstr])
Paramètre | Description |
---|---|
str |
Une expression de type chaîne de caractères. |
endlen |
La longueur de la chaîne de sortie. |
padstr |
Une chaîne de caractères qui est ajoutée à la chaîne de caractères d’origine jusqu’à la longueur spécifiée ( |
VARCHAR
ou BLOB
La fonction RPAD
complète la chaîne d’entrée de droite avec des espaces ou une chaîne définie par l’utilisateur jusqu’à une longueur spécifiée.
Caractéristiques d’utilisation :
La fonction prend en charge les blocs de texte de n’importe quelle longueur et avec n’importe quel jeu de caractères ;
Si la chaîne d’entrée est de type BLOB
, le résultat sera également BLOB, sinon le résultat sera VARCHAR(endlen)
.
Si l’argument padstr est donné mais est ''
(chaîne vide), aucune chaîne n’est ajoutée ! Dans le cas où endlen est inférieur à la longueur de la chaîne d’entrée, le résultat est tronqué à la longueur de endlen, même si padstr est une chaîne vide.
Warning
|
Lorsque vous utilisez |
RPAD
RPAD
RPAD ('Hello', 12) -- retourne 'Hello '
RPAD ('Hello', 12, '-') -- retourne 'Hello-------'
RPAD ('Hello', 12, '') -- retourne 'Hello'
RPAD ('Hello', 12, 'abc') -- retourne 'Helloabcabca'
RPAD ('Hello', 12, 'abcdefghij') -- retourne 'Helloabcdefg'
RPAD ('Hello', 2) -- retourne 'He'
RPAD ('Hello', 2, '-') -- retourne 'He'
RPAD ('Hello', 2, '') -- retourne 'He'
ASCII_VAL()
DSQL, PSQL
ASCII_VAL (ch)
Paramètre | Description |
---|---|
ch |
Type de données string [VAR]CHAR ou text BLOB d’une taille maximale de 32767 octets. |
SMALLINT
La fonction ASCII_VAL
renvoie le code ASCII du caractère passé en argument.
Caractéristiques d’utilisation :
Si la chaîne contient plus d’un caractère, le code du premier caractère de la chaîne est renvoyé ;
Si la chaîne est vide, elle renvoie null ;
Si l’argument est NULL
, la valeur de retour est également NULL
.
SUBSTRING()
DSQL, PSQL
SUBSTRING (<substring-args>) <substring-args> ::= str FROM startpos [FOR length] | str SIMILAR <similar_pattern> ESCAPE <escape> <similar-pattern> ::= <similar-pattern-R1> <escape>"<similar pattern_R2><escape>" <similar pattern-R3>
Paramètre | Description |
---|---|
str |
Une expression de type chaîne de caractères. |
startpos |
La position à laquelle l’extraction de la sous-chaîne commence. Expression entière. |
length |
Longueur de la sous-chaîne retournée. Expression entière. |
similar-pattern |
Le modèle de l’expression SQL régulière utilisée pour rechercher la sous-chaîne. |
escape |
Symbole d’échappement |
VARCHAR
ou BLOB
La fonction SUBSTRING
renvoie une sous-chaîne de caractères à partir d’une position donnée jusqu’à la fin de la chaîne ou jusqu’à une longueur spécifiée, ou extrait une sous-chaîne en utilisant un motif SQL régulier.
Si l’un des paramètres d’entrée est défini comme NULL
, le résultat sera également défini comme NULL
.
Warning
|
Lorsque vous utilisez |
SUBSTRING
Sous une forme positionnelle simple (avec FROM
), cette fonction renvoie une sous-chaîne commençant à la position du caractère startpos (la position du premier caractère est 1). Sans l’argument FOR
, il retourne tous les caractères restants dans la chaîne.Avec FOR, il renvoie les caractères longueur ou le reste de la chaîne, selon ce qui est le plus court.
A partir de Firebird 4.0, startpos peut être inférieur à 1.Lorsque startpos est inférieur à 1, la sous-chaîne se comporte comme si elle avait un 1 - startpos
supplémentaire devantle premier caractère réel à la position 1
.La valeur de length est comptée à partir de ce début imaginaire de la chaîne, donc la chaîne résultante peut être plus courte que la length spécifiée ou même vide.
La fonction prend entièrement en charge les BLOB binaires et textuels de n’importe quelle longueur et avec n’importe quel jeu de caractères.Si le paramètre str est de type BLOB
, le résultat sera également de type BLOB
.Pour tout autre type, le résultat est de type VARCHAR
.
Pour un paramètre d’entrée str qui n’est pas BLOB
, la longueur du résultat de la fonction sera toujours égale à la longueur de la chaîne str, quelles que soient les valeurs des paramètres startpos et length.
SUBSTRING
select substring('abcdef' from 1 for 2) from rdb$database;
-- Résultat: 'ab'
select substring('abcdef' from 2) from rdb$database;
-- Résultat: 'bcdef'
select substring('abcdef' from 0 for 2) from rdb$database;
-- Résultat: 'a'
-- pas "ab", car il n'y a pas de "rien" en position 0
select substring('abcdef' from -5 for 2) from rdb$database;
-- Résultat: ''
-- la longueur se termine avant le début réel de la ligne
SUBSTRING
par une expression régulièreLa fonction SUBSTRING
avec une expression régulière (avec SIMILAR
) retourne une partie d’une chaîne de caractères correspondant au modèle d’expression régulière du SQL. Si aucune correspondance n’est trouvée, NULL
est retourné.
Le motif SIMILAR
est formé de trois motifs d’expression régulière SQL : R1, R2 et R3. Le modèle complet a la forme R1 || '<escape>' || R2 || '<escape>' || R3
, où <escape> est le caractère d’échappement défini dans la clause ESCAPE
.R2 est le motif qui correspond à la sous-chaîne à extraire et qui est entouré de guillemets doubles échappés (<escape>
, par exemple, #"
avec le caractère d’échappement ‘`#’). R1 correspond au préfixe de la chaîne, et R3 au suffixe de la chaîne. R1 et R3 sont tous deux facultatifs (ils peuvent être vides), mais le motif doit correspondre à la chaîne entière. En d’autres termes, il ne suffit pas de spécifier un motif qui ne trouve qu’une sous-chaîne à extraire.
Tip
|
Les guillemets doubles échappés autour de R2 peuvent être comparés à la définition d’un groupe de capture unique dans une syntaxe d’expression régulière plus commune telle que PCRE. C’est-à-dire que le motif complet est équivalent à La valeur de retour correspond à la partie R2 de l’expression régulière. Pour cette valeur, l’expression est vraie.
|
Note
|
Si une partie d’un motif de R1, R2 ou R3 n’est pas une chaîne vide et n’a pas de format d’expression régulière SQL, une exception est levée. |
Le format complet des instructions SQL régulières est décrit dans le document suivant Syntaxe des expressions régulières SQL.
SUBSTRING
avec des expressions régulièresSUBSTRING('abcabc' SIMILAR 'a#"bcab#"c' ESCAPE '#') -- bcab
SUBSTRING('abcabc' SIMILAR 'a#"%#"c' ESCAPE '#') -- bcab
SUBSTRING('abcabc' SIMILAR '_#"%#"_' ESCAPE '#') -- bcab
SUBSTRING('abcabc' SIMILAR '#"(abc)*#"' ESCAPE '#') -- abcabc
SUBSTRING('abcabc' SIMILAR '#"abc#"' ESCAPE '#') -- <null>
TRIM()
DSQL, PSQL
TRIM ([<adjust>] str) <adjust> ::= {[<where>] [what]} FROM <where> ::= BOTH | LEADING | TRAILING
Paramètre | Description |
---|---|
str |
Une expression de type chaîne de caractères. |
where |
De quel endroit la sous-chaîne doit être retirée — |
what |
Une sous-chaîne à supprimer (plusieurs fois, s’il y a plus d’une occurrence) de la chaîne d’entrée str au début et/ou à la fin. Par défaut, il s’agit d’un espace. ( |
VARCHAR
ou BLOB
La fonction TRIM
supprime les espaces de début et/ou de fin (ou le texte tel que configuré) de la chaîne d’entrée.
Note
|
Caractéristiques d’utilisation
|
Warning
|
Lorsque vous utilisez |
TRIM
TRIM
SELECT TRIM (' Waste no space ')
FROM RDB$DATABASE -- Résultat: 'Waste no space'
SELECT TRIM (LEADING FROM ' Waste no space ')
FROM RDB$DATABASE -- Résultat: 'Waste no space '
SELECT TRIM (LEADING '.' FROM ' Waste no space ')
FROM RDB$DATABASE -- Résultat: ' Waste no space '
SELECT TRIM (TRAILING '!' FROM 'Help!!!!')
FROM RDB$DATABASE -- Résultat: 'Help'
SELECT TRIM ('la' FROM 'lalala I love you Ella')
FROM RDB$DATABASE -- Résultat: ' I love you El'
[fblangref-scalarfuncs-overlay], [fblangref-scalarfuncs-replace].
UNICODE_CHAR()
DSQL, PSQL
UNICODE_CHAR (number)
Paramètre | Description |
---|---|
number |
Un point de code UTF-32 acceptable se situe en dehors de la plage supérieure/inférieure des substituts (0xD800 à 0xDFFF). Sinon, une erreur sera émise. |
CHAR CHARACTER SET UTF8
La fonction UNICODE_CHAR
renvoie le caractère UNICODE pour un point de code donné.
UNICODE_CHAR
UNICODE_CHAR
select unicode_char(x) from y;
UNICODE_VAL()
DSQL, PSQL
UNICODE_VAL (string)
Paramètre | Description |
---|---|
string |
chaine de caractères. |
INTEGER
La fonction UNICODE_VAL
renvoie le point de code UTF-32 du premier caractère de la chaîne. Renvoie 0 pour une chaîne vide.
UNICODE_VAL
UNICODE_VAL
select unicode_val(x) from y;
UPPER()
DSQL, PSQL
UPPER (str)
Paramètre | Description |
---|---|
str |
Une expression de type chaîne de caractères. |
[VAR]CHAR
ou BLOB
La fonction UPPER
renvoie la chaîne de caractères d’entrée en majuscules. Le résultat exact dépend du jeu de caractères de la chaîne d’entrée. Par exemple, pour les jeux de caractères NONE et ASCII, seuls les caractères ASCII sont mis en majuscules ; pour les jeux de caractères OCTETS — la chaîne d’entrée entière est renvoyée inchangée.
UPPER
UPPER
select upper(_iso8859_1 'Débâcle')
from rdb$database
-- retourne 'DÉBÂCLE'
select upper(_iso8859_1 'Débâcle' collate fr_fr)
from rdb$database
-- retourne 'DEBACLE', Règles de mise en majuscules en français
-- résultat valide quand la BD est par défaut en UTF8 et le client configuré en iso8859_1
BASE64_DECODE()
DSQL, PSQL
BASE64_DECODE (base64_data)
Paramètre | Description |
---|---|
base64_data |
Données codées en base64 augmentées de |
`BLOB' ou `VARBINARY'.
BASE64_DECODE
décode une chaîne avec des données codées par l’algorithme base64et retourne la valeur décodée sous forme de VARBINARY
ou de BLOB
selon l’argument d’entrée.
Si la longueur du type base64_data n’est pas un multiple de 4, une erreur se produit pendant la préparation.Si la longueur de base64_data n’est pas un multiple de 4, une erreur se produit au moment de l’exécution.
Lorsque l’argument d’entrée n’est pas BLOB
, la longueur du type résultant est calculée comme suittype_length * 3/4
, où type_length est la longueur maximale en octets du type de l’argument d’entrée.
BASE64_DECODE
BASE64_DECODE
select cast(base64_decode('VGVzdCBiYXNlNjQ=') as varchar(12))
from rdb$database;
CAST ============ Test base64
BASE64_ENCODE()
DSQL, PSQL
BASE64_ENCODE (binary_data)
Paramètre | Description |
---|---|
binary_data |
Données binaires pour le codage |
VARCHAR CHARACTER SET ASCII
ou BLOB SUB_TYPE TEXT CHARACTER SET ASCII
.
La fonction BASE64_ENCODE
encode les données_binaires en utilisant l’algorithme base64 etrenvoie la valeur encodée sous la forme VARCHAR CHARACTER SET ASCII
ou BLOB SUB_TYPE TEXT CHARACTER SET ASCII
.selon le type de l’argument d’entrée.La valeur de retour est complétée par “`=`” afin que sa longueur soit un multiple de 4.
Lorsque l’argument d’entrée n’est pas BLOB
, la longueur du type résultant est calculée comme type_length * 4 / 3
, arrondie à un multiple de quatre, où type_length est la longueur maximale du type d’entrée en octets.
BASE64_ENCODE
BASE64_ENCODE
select base64_encode('Test base64')
from rdb$database;
BASE64_ENCODE ================ VGVzdCBiYXNlNjQ=
BIT_LENGTH()
DSQL, PSQL
BIT_LENGTH (string)
Paramètre | Description |
---|---|
string |
Une expression de type chaîne de caractères. |
BIGINT
La fonction BIT_LENGTH
renvoie la longueur de la chaîne d’entrée en bits.Pour les jeux de caractères multi-octets, le résultat peut être 8 fois le nombre de caractères dans le nombre formel
d’octets par caractère écrit dans RDB$CHARACTER_SETS
.
Avec les paramètres de type CHAR, cette fonction prend en compte la longueur totale de la chaîne formelle (par exemple, la longueur déclarée d’un champ ou d’une variable). Si vous voulez obtenir la longueur `logique' en bits, sans compter les espaces, vous devez effectuer une opération RIGHT TRIM sur l’argument avant de le passer à `BIT_LENGTH'.
BIT_LENGTH
BIT_LENGTH
SELECT BIT_LENGTH ('Hello!') FROM RDB$DATABASE
-- renvoie 48
SELECT BIT_LENGTH (_ISO8859_1 'Grüß Di!')
FROM RDB$DATABASE
-- retourne 64 : chacun, ü et ß occupent un octet en ISO8859_1
SELECT BIT_LENGTH (
CAST (_ISO8859_1 'Grüß di!' AS VARCHAR (24)
CHARACTER SET UTF8))
FROM RDB$DATABASE
-- renvoie 80 : ü et ß occupent chacun deux octets en UTF8.
SELECT BIT_LENGTH (
CAST (_ISO8859_1 'Grüß di!' AS CHAR (24)
CHARACTER SET UTF8))
FROM RDB$DATABASE
-- renvoie 208 : la taille de l'ensemble des 24 positions CHAR et deux d'entre elles sont de 16 bits
CHAR_LENGTH()
, CHARACTER_LENGTH()
DSQL, PSQL
CHAR_LENGTH (string) | CHARACTER_LENGTH (string)
Paramètre | Description |
---|---|
string |
Une expression de type chaîne de caractères. |
BIGINT
La fonction CHAR_LENGTH
renvoie la longueur (en caractères) de la chaîne passée en argument.
Note
|
Avec des paramètres de type |
HASH()
DSQL, PSQL
HASH (str [USING <algorithm>]) <algorithm> ::= { CRC32 }
Paramètre | Description |
---|---|
str |
Une expression de type chaîne de caractères. |
BIGINT
La fonction HASH
renvoie un hachage non cryptographique de la chaîne d’entrée.Cette fonction prend entièrement en charge les `BLOB' de texte de n’importe quelle longueur et avec n’importe quel jeu de caractères.
La clause facultative USING
spécifie l’algorithme de hachage non cryptographique à appliquer.Lorsque la clause USING
n’est pas présente, l’algorithme PJW est appliqué, comme dans les versions précédentes de Firebird.
Si aucun algorithme n’est spécifié, une version 64 bits de l’algorithme non cryptographique est utilisée.https://en.wikipedia.org/wiki/PJW_hash_function [fonction de hachage PJW^] (également connue sous le nom de ELF64) est utilisée.Cette fonction est très rapide et peut être utilisée à des fins générales (tables de hachage, etc.) mais présente un grand nombre de collisions.Pour un hachage plus sûr, vous devriez utiliser d’autres fonctions de hachage, explicitement spécifiées dans la clause USING, ou des hachages cryptographiques avec [fblangref-scalarfuncs-crypthash].
Pour cet algorithme de hachage, la fonction renvoie le type BIGINT
.
CRC32
Si la clause USING
spécifie l’algorithme CRC32
, Firebird applique l’algorithme CRC32 en utilisant le polynôme 0x04C11DB7.
Pour cet algorithme, la fonction HASH
renvoie un résultat de type INTEGER
.
HASH
SELECT HASH(x) FROM MyTable;
-- résultat du type BIGINT
SELECT HASH(x USING CRC32) FROM MyTable;
-- résultat du type INTEGER
Voir aussi :[fblangref-scalarfuncs-crypthash]
HEX_DECODE()
DSQL, PSQL
HEX_DECODE (hex_data)
Paramètre | Description |
---|---|
hex_data |
Données en représentation hexadécimale. |
VARBINARY
ou BLOB
.
La fonction HEX_DECODE
décode une chaîne de caractères avec des données hexadécimales et retourne la valeur décodée.comme VARBINARY
ou BLOB
selon le type d’entrée et la taille de l’argument.Si la longueur du type hex_data n’est pas un multiple de 2, une erreur se produit pendant la préparation.Si la longueur de hex_data n’est pas un multiple de 2, une erreur se produit au moment de l’exécution.
Lorsque l’argument d’entrée n’est pas BLOB
, la longueur du type résultant est calculée comme type_length / 2
,où type_longueur est la longueur maximale en octets du type de l’argument d’entrée.
HEX_DECODE
HEX_DECODE
select cast(hex_decode('48657861646563696D616C') as varchar(12))
from rdb$database;
CAST ============ Hexadecimal
HEX_ENCODE()
DSQL, PSQL
HEX_ENCODE (binary_data)
Paramètre | Description |
---|---|
binary_data |
Données binaires pour le codage |
VARCHAR CHARACTER SET ASCII
ou BLOB SUB_TYPE TEXT CHARACTER SET ASCII
La fonction HEX_ENCODE
encode les données binaires avec un nombre hexadécimal et retourne la valeur encodée sous forme de VARCHAR CHARACTER SET ASCII
ou de BLOB SUB_TYPE TEXT CHARACTER SET ASCII
selon l’argument d’entrée.
Lorsque l’argument d’entrée n’est pas BLOB
, la longueur du type résultant est calculée comme type_length * 2
, où type_length est la longueur maximale en octets du type de l’argument d’entrée.
HEX_ENCODE
HEX_ENCODE
select hex_encode('Hexadecimal')
from rdb$database;
HEX_ENCODE ====================== 48657861646563696D616C
DATEADD()
DSQL, PSQL
DATEADD (<args>) <args> ::= <amount> <unit> TO <datetime> | <unit>, <amount>, <datetime> <unit> ::= YEAR | MONTH | WEEK | DAY | WEEKDAY | YEARDAY | HOUR | MINUTE | SECOND | MILLISECOND
Paramètre | Description |
---|---|
amount |
Une expression de type |
unit |
Composante date/heure. |
datetime |
Une expression de type |
DATE
, TIME
ou TIMESTAMP
.
La fonction DATEADD
vous permet d’ajouter un nombre donné d’années, de mois, de semaines, d’heures, de minutes, de secondes, de millisecondes à une valeur de date/heure donnée.
Note
|
|
DATEADD
DATEADD
DATEADD (28 DAY TO CURRENT_DATE)
DATEADD (-6 HOUR TO CURRENT_TIME)
DATEADD (MONTH, 9, DATEOFCONCEPTION)
DATEADD (-38 WEEK TO DATEOFBIRTH)
DATEADD (MINUTE, 90, CAST('NOW' AS TIME))
DATEADD (? YEAR TO DATE '11-SEP-1973')
SELECT
CAST(DATEADD(-1 * EXTRACT(MILLISECOND FROM ts) MILLISECOND TO ts) AS VARCHAR(30)) AS t,
EXTRACT(MILLISECOND FROM ts) AS ms
FROM (
SELECT TIMESTAMP'2014-06-09 13:50:17.4971' as ts
FROM RDB$DATABASE
) a
T MS ------------------------------------ 2014-06-09 13:50:17.0000 497.1
DATEDIFF()
DSQL, PSQL
DATEDIFF (<args>) <args> ::= <unit> FROM <moment_1> TO <moment_2> | <unit>, <moment_1>, <moment_2> <unit> ::= YEAR | MONTH | WEEK | DAY | WEEKDAY | YEARDAY | HOUR | MINUTE | SECOND | MILLISECOND
Paramètre | Description |
---|---|
unit |
Composante date/heure. |
monent_1 |
Une expression de type |
monent_2 |
Une expression de type |
BIGINT
La fonction DATEDIFF
renvoie le nombre d’années, de mois, de semaines, de jours, d’heures, de minutes, de secondes ou de millisecondes entre deux valeurs de date/heure.
Caractéristiques d’utilisation :
Les paramètres DATE
et TIMESTAMP
peuvent être utilisés ensemble. La co-utilisation du type TIME
avec le type DATE
et TIMESTAMP
n’est pas autorisée ;
Avec un argument de type TIMESTAMP
et DATE
, n’importe quel composant date/heure <unit> peut être utilisé ;
Seuls HOUR
, MINUTE
, SECOND
et MILLISECOND
peuvent être utilisés pour le type de données TIME.
Note
|
|
DATEDIFF
DATEDIFF
DATEDIFF (HOUR FROM CURRENT_TIMESTAMP TO TIMESTAMP '12-JUN-2059 06:00')
DATEDIFF (MINUTE FROM TIME '0:00' TO CURRENT_TIME)
DATEDIFF (MONTH, CURRENT_DATE, DATE '1-1-1900')
DATEDIFF (DAY FROM CURRENT_DATE TO CAST (? AS DATE))
EXTRACT()
DSQL, PSQL
EXTRACT (<part> FROM <datetime>) <part> ::= YEAR | MONTH | WEEK | DAY | WEEKDAY | YEARDAY | HOUR | MINUTE | SECOND | MILLISECOND | TIMEZONE_HOUR | TIMEZONE_MINUTE
Paramètre | Description |
---|---|
part |
Composante date/heure. |
datetime |
Une expression de type |
SMALLINT
ou NUNERIC
.
La fonction EXTRACT
extrait les composants de date et d’heure des types de données DATE
, TIME
et TIMESTAMP
.
Composant date/heure | Type | Plage | Commentaire |
---|---|---|---|
|
|
1–9999 |
L’année |
|
|
1-4 |
Trimestre |
|
|
1–12 |
Mois |
|
|
1–53 |
Numéro de la semaine de l’année |
|
|
1–31 |
Jour |
|
|
0–6 |
Jour de la semaine. 0 — Dimanche |
|
|
0–365 |
Le numéro du jour de l’année. 0 = 1 janvier |
|
|
0–23 |
Heure |
|
|
0–59 |
Minute |
|
|
0.0000–59.9999 |
Secondes. Inclut les millisecondes |
|
|
0.0–999.9 |
Millisecondes |
|
|
de -14 à +14 |
Décalage des heures du fuseau horaire |
|
|
de -59 à +59 |
Décalage des minutes du fuseau horaire |
Note
|
Si le composant date/heure n’est pas présent dans l’argument date/heure, par exemple SECOND dans un argument de type DATE ou YEAR dans TIME, la fonction provoquera une erreur. |
À partir d’un argument de type DATE
ou TIMESTAMP
, vous pouvez extraire le numéro de la semaine. Selon la norme ISO-8601, la semaine commence le lundi et comprend toujours 7 jours. La première semaine de l’année est celle qui compte le plus de jours dans la nouvelle année (au moins 4) : les jours 1-3 peuvent appartenir à la semaine précédente (52 ou 53) de l’année précédente. Par analogie, les jours 1-3 de l’année en cours peuvent appartenir à la semaine 1 de l’année suivante.
EXTRACT
/* récupérer le numéro du trimestre par la date */
SELECT (EXTRACT(MONTH FROM CURRENT_TIMESTAMP)-1)/3+1
FROM RDB$DATABASE
FIRST_DAY()
DSQL, PSQL
FIRST_DAY(OF <period> FROM date_or_timestamp) <period> ::= YEAR | QUARTER | MONTH | WEEK
Paramètre | Description |
---|---|
date_or_timestamp |
Une expression de type |
DATE
ou TIMESTAMP [WITH | WITHOUT] TIME ZONE
.
Renvoie le premier jour de l’année, du mois ou de la semaine pour une date donnée.
Note
|
|
FIRST_DAY
FIRST_DAY
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 '2022-11-01') FROM rdb$database;