Ver Mensaje Individual
  #1  
Antiguo 30-08-2017
IVAND IVAND is offline
Miembro
 
Registrado: may 2003
Ubicación: ECUADOR
Posts: 523
Reputación: 21
IVAND Va por buen camino
Storep procedure con execute statment

Hola a todos de antemano gracias por su amable ayuda

Explico mi problema

trato de llenar una tabla que tiene los siguientes campos
codigo varchar(20)
cantidad numeric(15,2)

como se dieron cuenta se executa una sentencia execute statement donde el problema es que el campo q intento insertar es de tipo varchar y me da error al insertar

como puedo indicarle a este valor las comillas para q se ejecute bien

ejemplo

insert into prueba (codigo,enero) values (1.01.1,-1.10)


ahi se produce el error pues deberia ser insert into prueba (codigo,enero) values ('1.01.1',-1.10)

Código SQL [-]
create or alter procedure LLENAR_PIVOT
as
declare variable CODI varchar(20);
declare variable NOMB varchar(100);
declare variable TCNOMBRETABLA varchar(10);
declare variable LCCOLUMNA varchar(10);
declare variable CANTIDAD numeric(15,2);
declare variable LCUPDATE varchar(4096);
begin
tcNombreTabla='PRUEBA'  ;

FOR  select p.codigo,p.nombre,
case
WHEN extract(month from c.fecha_diario)=1 Then 'ENERO'
WHEN extract(month from c.fecha_diario)=2 THEN 'FEBRERO'
WHEN extract(month from c.fecha_diario)=3 THEN 'MARZO'
End mes
,sum(debe-haber) monto
 from cab_diario c , det_diario d ,plan_ctas p
where c.key_cab_diario=d.key_cab_diario
and c.estado='T'
and d.key_plan_ctas=p.key_plan_ctas
and extract(month from c.fecha_diario)<=3
Group by 1,2,3  INTO
      :codi,
      :nomb,
      :lcColumna,
      :Cantidad
   DO BEGIN
      lcColumna = Left(lcColumna, 28);
      lcUpdate = 'UPDATE OR INSERT INTO ' ||
                 tcNombreTabla || ' (' ||
                 'CODIGO, ' || lcColumna || ') VALUES (' ||
                 codi ||', '||
                 Cantidad || ') MATCHING codigo';
      EXECUTE STATEMENT lcUpdate;
      End

end
__________________
IVAND

Última edición por IVAND fecha: 30-08-2017 a las 04:23:09.
Responder Con Cita