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.