[firebase-br] Migrar Firebird 3 para 5

Gladiston Santana gladiston.santana em gmail.com
Sexta Dezembro 19 16:14:56 -03 2025


Funções para MOD e ABS já existem acho que desde a 2.5.
STRLEN poderia trocar CHAR_LENGTH
SUBSTR poderia trocar por SUBSTRING
RTRIM  poderia trocar por TRIM e TRIM+TRAILING:

> SELECT TRIM(TRAILING FROM '    Remove Espaços      ') FROM RDB$DATABASE;
> // Retorna 'Remove Espaços'
> SELECT TRIM(TRAILING '.' FROM 'Removendo pontos no final!....') FROM
> RDB$DATABASE; // Retorna 'Removendo pontos no final!'
>
O LTRIM voce teria que criar uma SQL Function para isso, ex:

> CREATE OR ALTER FUNCTION LTRIM_CUSTOM (
>     STR VARCHAR(32765)
> ) RETURNS VARCHAR(32765)
> AS
> DECLARE VARIABLE POS INTEGER = 1;
> DECLARE VARIABLE LEN INTEGER;
> BEGIN
>   IF (STR IS NULL) THEN
>       RETURN NULL;
>   LEN = CHAR_LENGTH(STR);
>   -- Percorre a string enquanto encontrar espaços
>   WHILE (POS <= LEN AND SUBSTRING(STR FROM POS FOR 1) = ' ') DO
>   BEGIN
>       POS = POS + 1;
>   END
>   -- Se POS ultrapassou LEN, a string só tinha espaços
>   IF (POS > LEN) THEN
>       RETURN '';
>   ELSE
>       -- Retorna do primeiro caractere não-espaço em diante
>       RETURN SUBSTRING(STR FROM POS);
> END

Ex:
SELECT LTRIM_CUSTOM('     teste123') FROM RDB$DATABASE;  // retorna
'Teste123'

Remova as dependências de UDF e depois faça backup e restaure no 5.

[]'s e sucesso.

Em sex., 19 de dez. de 2025 às 10:39, Max Wolfring via lista <
lista em firebase.com.br> escreveu:

> Bom dia!Estamos migrando banco de dados do Firebird 3 para o 5 e recebemos
> a mensagem:
> gbak: WARNING:function STRLEN is not defined
> gbak: WARNING:    module name or entrypoint could not be found
> gbak: WARNING:    function SUBSTR is not defined
> gbak: WARNING:    module name or entrypoint could not be found
> gbak: WARNING:    function LTRIM is not defined
> gbak: WARNING:    module name or entrypoint could not be found
> gbak: WARNING:    function RTRIM is not defined
> gbak: WARNING:    module name or entrypoint could not be found
> gbak: WARNING:    function ABS is not defined
> gbak: WARNING:    module name or entrypoint could not be found
> gbak: WARNING:    function MOD is not defined
> gbak: WARNING:    module name or entrypoint could not be foundExecutamos o
> script conforme recomendado no livro sobre migração para o Firebird 4 do
> Cantu:/opt/firebird/bin/isql -user sysdba -pas 4b6f4194 -i
> /opt/firebird/misc/upgrade/udf/udf_replace.sql banco.fdb
> e isso resolve quase tudo, continua dando mensageem nas funções MOD e ABS,
> como posso resolver isso?


Mais detalhes sobre a lista de discussão lista