Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > Conexión con bases de datos
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Conexión con bases de datos

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 26-07-2005
Avatar de BlueSteel
[BlueSteel] BlueSteel is offline
Miembro Premium
 
Registrado: may 2003
Ubicación: Concepción - Chile
Posts: 2.310
Poder: 23
BlueSteel Va por buen camino
Exclamation Crear Trigger y llamarlo desde Delphi

Hola...

Hace algun tiempo he tenido problemas para que un registro se actualice, consultado por aquí y por allá, me dieron a entender que sería mejor que empezara a utilizar los famosos triggers, los cuales aún no los se usar bien...

bueno... primero que nada quiero crear el triggers, el cual me permita actualizar los siguientes datos: ( se me olvidaba, trabajo con interbase 6 )

Tabla = Orden
Campos = Ord_Neto : Float, Ord_Descuento : Float, Ord_Iva : Float
Campo Clave = Ord_Numero : Varchar

hasta elmomento llevo esto.. pero me sale error...

Código:
AS
BEGIN
  update Orden
  Set Ord_Neto = new."Ord_Neto", Ord_Descuento = new."Ord_Descuento", Ord_Iva = new."Ord_Iva"
  where Ord_Numero = new."Ord_Numero";
END
Una vez creado esto, como sería la forma de llamarlo desde Delphi ?(7 Studio)

bueno, demás esta decir que agradesco cualquier aporte...
__________________
BlueSteel
Responder Con Cita
  #2  
Antiguo 26-07-2005
[maeyanes] maeyanes is offline
Capo de los Capos
 
Registrado: may 2003
Ubicación: Campeche, México
Posts: 2.732
Poder: 23
maeyanes Va por buen camino
Los triggers no pueden llamarse directamente desde Delphi o cualquier otro ambiente de desarrollo. Estos están diseñados para dispararse cuando ejecutas una acción en una tabla o registro (insert, update, delete).


Saludos...
Responder Con Cita
  #3  
Antiguo 26-07-2005
Avatar de BlueSteel
[BlueSteel] BlueSteel is offline
Miembro Premium
 
Registrado: may 2003
Ubicación: Concepción - Chile
Posts: 2.310
Poder: 23
BlueSteel Va por buen camino
Suata...

entonce que puedo hacer para solucionar mi problema... me explico...

Es un sistema de Ordenes de Compra... en donde un modulo es para modificar Ordenes que estan en Garantía....

La idea es poder agregar o quitar items de la orden (Tabla : DOrden), y actualizar los respectivos valores netos y de Iva (Tabla:Orden), para lo cual realizo el siguiente procedimiento:

Agrega Item (Tabla DOrden)
Código:
vTot.Text := FloatToStr(RoundN(StrToFloat(vCtd.Text)*StrToFloat(vUni.Text)));
IBQ_Edit.SQL.Clear;
IBQ_Edit.SQL.Add('Insert Into "DOrden" ("Ord_Numero","Dor_Descripcion",	   "Dor_Cantidad","Dor_Valor_Unitario")');
IBQ_Edit.SQL.Add('Values (:P1,:P2, :P3, :P4)');
IBQ_Edit.Params[0].AsString := nOrd.Text;
IBQ_Edit.Params[1].AsString := vDes.Text;
IBQ_Edit.Params[2].AsInteger := StrToInt(vCtd.Text);
IBQ_Edit.Params[3].AsFloat := StrToFloat(vUni.Text);
IBQ_Edit.ExecSQL;
vTot_Bru.Text := IntToStr(StrToInt(vTot.Text)+StrToInt(vTot_Net.Text));
 
Actualiza_Orden;
Elimina (Tabla DOrden)
Código:
IBQ_Edit.SQL.Clear;
IBQ_Edit.SQL.Add('Delete From "DOrden"');
IBQ_Edit.SQL.Add('Where "Dor_Numero"=:Var1');
IBQ_Edit.Params[0].AsString := IBQ_Items['Dor_Numero'];
IBQ_Edit.ExecSQL;
vTot_Bru.Text := FloatToStr(StrToFloat(vTot_Bru.Text)-Total_Item);
Procedimiento para actualizar calculos y Tabla :Orden
Código:
procedure TModifica_OC.Actualiza_Orden;
begin
  vTot_Net.Text := FloatToStr(StrToFloat(vTot_Bru.Text)-StrToFloat(vTot_Des.Text));
  If CB_Factura.Checked = True Then
	 vTot_Iva.Text := '0'
  Else
	 vTot_Iva.Text := FloatToStr(RoundN(StrToFloat(vTot_Net.Text)*vIva));
  vTot_Fin.Text := FloatToStr(RoundN(StrToFloat(vTot_Iva.Text)+StrToFloat(vTot_Net.Text)));
  IBQ_Edit.SQL.Clear;
  IBQ_Edit.SQL.Add('Update "Orden" Set "Ord_Neto"=:Var1,"Ord_Descuento"=:Var2, "Ord_Iva"=:Var3');
  IBQ_Edit.SQL.Add('Where "Ord_Numero"=:Var4');
  IBQ_Edit.Params[0].AsFloat := StrToFloat(vTot_Bru.Text);
  IBQ_Edit.Params[1].AsFloat := StrToFloat(vTot_Des.Text);
  IBQ_Edit.Params[2].AsFloat := StrToFloat(vTot_Iva.Text);
  IBQ_Edit.Params[3].AsString := Ordenes.Num_Orden;
  IBQ_Edit.ExecSQL;
 
  IBT_Edit.Commit;	 // Actualiza cambios en Tabla :Dorden
  IBT_Items.Commit; // Actualiza cambios en Tabla :Orden
end;
Bueno... cada vez que elimino o agrego un item a la Orden de Compra, estos datos se actualizan en la Tabla Dorden, pero se supone que tambien los actualizo en la Tabla Orden, pero cuando salgo del modulo y reviso la orden que habia modificado, solo estan las actualizaciones de los items (Tabla Dorden), pero los valores totales no se han modificados (Tabla Orden), que podrá ser....
__________________
BlueSteel
Responder Con Cita
Respuesta



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


La franja horaria es GMT +2. Ahora son las 06:07:25.


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