MariaDB
 sql >> Base de données >  >> RDS >> MariaDB

MariaDB RTRIM() vs RTRIM_ORACLE() :Quelle est la différence ?

MariaDB a un RTRIM() fonction et un RTRIM_ORACLE() une fonction. Les deux fonctions font essentiellement la même chose. Mais il y a une petite différence.

La différence

La différence réside dans la façon dont chaque fonction traite les chaînes vides :

  • RTRIM() supprime les espaces de fin d'une chaîne. Lorsque vous passez une chaîne vide, le résultat dépendra si vous êtes en mode Oracle ou non. Si en mode Oracle, il renvoie null . Sinon, il renvoie une chaîne vide.
  • RTRIM_ORACLE() est un synonyme de la version en mode Oracle de RTRIM() . Il se comporte comme RTRIM() en mode Oracle (il renvoie null lorsqu'une chaîne vide est transmise), même lorsqu'il n'est pas en mode Oracle.

Donc RTRIM_ORACLE() fonctionne exactement comme RTRIM() en mode Oracle. Mais lorsqu'il n'est pas en mode Oracle, la seule différence est la façon dont chaque fonction traite les chaînes vides.

Exemple

Ceci est mieux expliqué avec un exemple.

Mode par défaut

Voici une comparaison de ces fonctions en mode par défaut :

SET SQL_MODE=DEFAULT;
SELECT
    RTRIM(''),
    RTRIM_ORACLE('');

Résultat :

+-----------+------------------+
| RTRIM('') | RTRIM_ORACLE('') |
+-----------+------------------+
|           | NULL             |
+-----------+------------------+

Tout d'abord, j'ai mis mon système en mode par défaut (même s'il était probablement déjà en mode par défaut), puis j'ai exécuté les deux fonctions avec une chaîne vide.

Nous pouvons voir que RTRIM() renvoie une chaîne vide, tandis que RTRIM_ORACLE() renvoie null .

Mode Oracle

Passons maintenant au mode Oracle et réexécutons le code :

SET SQL_MODE=ORACLE;
SELECT
    RTRIM(''),
    RTRIM_ORACLE('');

Résultat :

+-----------+------------------+
| RTRIM('') | RTRIM_ORACLE('') |
+-----------+------------------+
| NULL      | NULL             |
+-----------+------------------+

Nous pouvons voir que RTRIM() se comporte maintenant comme RTRIM_ORACLE() .

Donc, avec RTRIM() , nous devons passer explicitement en mode Oracle avant de le faire se comporter comme la version Oracle de RTRIM() .

RTRIM_ORACLE() d'autre part, est disponible dans tous les modes, ce qui nous évite d'avoir à passer en mode Oracle.