MariaDB ha un RTRIM()
funzione e un RTRIM_ORACLE()
funzione. Entrambe le funzioni fanno essenzialmente la stessa cosa. Ma c'è una piccola differenza.
La differenza
La differenza sta nel modo in cui ciascuna funzione gestisce le stringhe vuote:
RTRIM()
rimuove gli spazi finali da una stringa. Quando viene passata una stringa vuota, il risultato dipenderà dal fatto che tu sia in modalità Oracle o meno. Se in modalità Oracle, restituiscenull
. Altrimenti restituisce una stringa vuota.RTRIM_ORACLE()
è un sinonimo della versione in modalità Oracle diRTRIM()
. Si comporta comeRTRIM()
in modalità Oracle (restituiscenull
quando viene passata una stringa vuota), anche quando non è in modalità Oracle.
Quindi RTRIM_ORACLE()
funziona esattamente come RTRIM()
quando in modalità Oracle. Ma quando non è in modalità Oracle, l'unica differenza è il modo in cui ciascuna funzione gestisce le stringhe vuote.
Esempio
Questo è meglio spiegato con un esempio.
Modalità predefinita
Ecco un confronto di queste funzioni in modalità predefinita:
SET SQL_MODE=DEFAULT;
SELECT
RTRIM(''),
RTRIM_ORACLE('');
Risultato:
+-----------+------------------+ | RTRIM('') | RTRIM_ORACLE('') | +-----------+------------------+ | | NULL | +-----------+------------------+
Innanzitutto, ho impostato il mio sistema sulla modalità predefinita (anche se probabilmente era già in modalità predefinita), quindi ho eseguito entrambe le funzioni con una stringa vuota.
Possiamo vedere che RTRIM()
restituisce una stringa vuota, mentre RTRIM_ORACLE()
restituisce null
.
Modalità Oracle
Ora impostiamolo in modalità Oracle ed eseguiamo nuovamente il codice:
SET SQL_MODE=ORACLE;
SELECT
RTRIM(''),
RTRIM_ORACLE('');
Risultato:
+-----------+------------------+ | RTRIM('') | RTRIM_ORACLE('') | +-----------+------------------+ | NULL | NULL | +-----------+------------------+
Possiamo vedere che RTRIM()
ora si comporta come RTRIM_ORACLE()
.
Quindi, con RTRIM()
, dobbiamo passare esplicitamente alla modalità Oracle prima che si comporti come la versione Oracle di RTRIM()
.
RTRIM_ORACLE()
d'altra parte, è disponibile in tutte le modalità, quindi ci evita di dover passare alla modalità Oracle.