Club Delphi  
    Paypal   FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Bases de datos > Firebird e Interbase
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

 
 
Herramientas Buscar en Tema Desplegado
  #2  
Antiguo 06-03-2008
Avatar de defcon1_es
defcon1_es defcon1_es is offline
Miembro
 
Registrado: mar 2004
Ubicación: Cuenca - España
Posts: 533
Poder: 23
defcon1_es Va por buen camino
Cita:
Empezado por arturom Ver Mensaje
if Column.Title.Caption = 'Precio' then begin
// Rellena el query -> Esto no es un TIBQuery, sino un TIBDataSet
dmDatos.dsArticulos.Close;
dmDatos.dsArticulos.ModifySQL.Clear;
dmDatos.dsArticulos.ModifySQL.Add('update ARTICULOS set PRECIO = :Precio where REFERENCIA = :Referencia');
// Pide el nuevo precio
sPrecio:= InputBox('Nuevo precio', 'Nuevo precio', '0');
try
// Modifica el precio
dPrecio:= StrToFloat(sPrecio);
if dPrecio> 0 then begin
dmDatos.dsArticulos.Params.ByName('Precio').AsFloat := dPrecio; // <---- AQUÍ FALLA
dmDatos.dsArticulos.Params.ByName('Referencia').AsString:= dmDatos.dsArticulosREFERENCIA.Value;
dmDatos.dsArticulos.Open;
end;
except
raise Exception.CreateFmt('El nuevo precio no es correcto',[]);
end;

al ejecutarlo me da el error 'Field "Precio" not found', es evidente que el campo Precio si que existe en la tabla.

El caso es que en todos los sitios que busco la forma de pasar los parámetros es:

dsArticulos.ParamByName('Referencia').AsString := 'cadena';

pero a mi me dice que no tiene ese procedimiento, solo puedo usar la forma:

dsArticulos.Params.ByName('Referencia').AsString := 'cadena';
¿No sería más sencillo usar un TIBQuery en vez del TIBDataSet?
Código Delphi [-]
if Column.Title.Caption = 'Precio' 
then begin   
  dmDatos.dsArticulosQuery.Close;   
  dmDatos.dsArticulosQuery.SQL.Clear;   
  dmDatos.dsArticulosQuery.SQL.Add('update ARTICULOS set PRECIO = :Precio where REFERENCIA = :Referencia');
// Pide el nuevo precio
  sPrecio:= InputBox('Nuevo precio', 'Nuevo precio', '0');
  try  // Modifica el precio
    dPrecio:= StrToFloat(sPrecio);
    if dPrecio> 0 
    then begin       
      dmDatos.dsArticulosQuery.ParamByName('Precio').AsFloat := dPrecio; 
      dmDatos.dsArticulosQuery.ParamByName('Referencia').AsString := 
        dmDatos.dsArticulosREFERENCIA.Value;
      dmDatos.dsArticulosQuery.Open;
    end;
  except     
    raise Exception.CreateFmt('El nuevo precio no es correcto',[]);
  end;
end;
__________________
Progress Openedge
https://abevoelker.com/progress_open...dered_harmful/


Delphi forever...
Responder Con Cita
 



Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro

Temas Similares
Tema Autor Foro Respuestas Último mensaje
Paso de parametros Delphos Varios 4 18-01-2005 15:32:07
Paso de parametros senpiterno Varios 1 11-04-2004 03:44:17
paso de parametros gustavo2 SQL 7 16-01-2004 15:46:23
Paso de parametros __cadetill PHP 2 12-08-2003 10:15:09
Paso de Parámetros vinny Varios 1 29-05-2003 12:54:07


La franja horaria es GMT +2. Ahora son las 03:23:15.


Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi
Copyright 1996-2007 Club Delphi