MariaDB
 sql >> Base de Dados >  >> RDS >> MariaDB

MariaDB LTRIM() vs LTRIM_ORACLE():Qual é a diferença?


MariaDB tem um LTRIM() função e um LTRIM_ORACLE() função. Ambas as funções fazem essencialmente a mesma coisa. Mas há uma pequena diferença.

A diferença


A diferença está em como cada função lida com strings vazias:
  • LTRIM() remove os espaços iniciais de uma string. Ao passar uma string vazia, o resultado dependerá de você estar no modo Oracle ou não. Se estiver no modo Oracle, retorna null . Caso contrário, ele retornará uma string vazia.
  • LTRIM_ORACLE() é um sinônimo para a versão do modo Oracle de LTRIM() . Ele se comporta como LTRIM() no modo Oracle (retorna null quando passou uma string vazia), mesmo quando não estiver no modo Oracle.

Então LTRIM_ORACLE() funciona exatamente como LTRIM() quando no modo Oracle. Mas quando não está no modo Oracle, a única diferença é como cada função lida com strings vazias.

Exemplo


Isso é melhor explicado com um exemplo.

Modo padrão


Aqui está uma comparação dessas funções no modo padrão:
SET SQL_MODE=DEFAULT;
SELECT
    LTRIM(''),
    LTRIM_ORACLE('');

Resultado:
+-----------+------------------+
| LTRIM('') | LTRIM_ORACLE('') |
+-----------+------------------+
|           | NULL             |
+-----------+------------------+

Primeiro, configurei meu sistema para o modo padrão (mesmo que provavelmente já estivesse no modo padrão), depois executei as duas funções com uma string vazia.

Podemos ver que LTRIM() retorna uma string vazia, enquanto LTRIM_ORACLE() retorna null .

Modo Oráculo


Agora vamos configurá-lo para o modo Oracle e executar o código novamente:
SET SQL_MODE=ORACLE;
SELECT
    LTRIM(''),
    LTRIM_ORACLE('');

Resultado:
+-----------+------------------+
| LTRIM('') | LTRIM_ORACLE('') |
+-----------+------------------+
| NULL      | NULL             |
+-----------+------------------+

Podemos ver que LTRIM() agora se comporta como LTRIM_ORACLE() .

Então, com LTRIM() , precisamos mudar explicitamente para o modo Oracle antes que ele se comporte como a versão Oracle de LTRIM() .

LTRIM_ORACLE() por outro lado, está disponível em todos os modos, o que nos poupa de ter que mudar para o modo Oracle.