Não é possível criar o procedimento armazenado do Informix usando o comando ISQL?

Estou tendo problemas ao criar este procedimento armazenado no IBM Informix Dynamic Server Versão 10.00.FC9 (consulte a resposta de Jonathan Leffler a este postAqui) usando o comando 'isql' do Informix SQL.

Eu recebo um erro no( char para cada um dos seus dois exemplos pertoRETURNING CHAR(8)

ex. 1:

CREATE PROCEDURE ampm_time(tm SMALLINT) RETURNING CHAR(8);
    DEFINE hh SMALLINT;
    DEFINE mm SMALLINT;
    DEFINE am SMALLINT;
    DEFINE m3 CHAR(3);
    DEFINE a3 CHAR(3);
    LET hh = MOD(tm / 100 + 11, 12) + 1;
    LET mm = MOD(tm, 100) + 100;
    LET am = MOD(tm / 1200, 2);
    LET m3 = mm;
    IF am = 0
    THEN LET a3 = ' am';
    ELSE LET a3 = ' pm';
    END IF;
    RETURN (hh || ':' || m3[2,3] || a3);
END PROCEDURE;

ex. 2:

CREATE PROCEDURE ampm_time(tm SMALLINT) RETURNING CHAR(8);
    DEFINE i2 SMALLINT;
    DEFINE hh SMALLINT;
    DEFINE mm SMALLINT;
    DEFINE am SMALLINT;
    DEFINE m3 CHAR(3);
    DEFINE a3 CHAR(3);
    LET i2 = tm / 100;
    LET hh = MOD(i2 + 11, 12) + 1;
    LET mm = MOD(tm, 100) + 100;
    LET i2 = tm / 1200;
    LET am = MOD(i2, 2);
    LET m3 = mm;
    IF am = 0
    THEN LET a3 = ' am';
    ELSE LET a3 = ' pm';
    END IF;
    RETURN (hh || ':' || m3[2,3] || a3);
END PROCEDURE;

Eles foram projetados por Jonathan Leffler (Informix Magician extraordinaire) em um esforço para resolver a pergunta que fiz no post vinculado. O retorno pretendido é converter um tipo de dados INT mantendo o horário militar em um formato do tipo 2:30 pm.

questionAnswers(1)

yourAnswerToTheQuestion