Hola gente:
Bueno traigo este tema de un hilo que fue concluido hace un par de horas y llevo hasta 80 post. Tal vez por malos entendidos y demas yerbas pero fue bastante largo. Al final era una cuestion de eventos de la base de datos, como capturarlos y aqui comenzaron mis problemas:
Empece a hacer un programita sencillo para poder probar los eventos que me informaba la base de datos (Firebird), arme un trigger para que me informara cuando se agregara un registro y asi capturarlo por el IbEvents. El trigger esta programado asi:
Código SQL
[-]CREATE TRIGGER POST_NEW_REG FOR CLIENTES
ACTIVE AFTER INSERT
POSITION 0
AS
BEGIN
POST_EVENT 'new_reg';
END
a partir de ahi puse un TIbEvents en el datamodule del programita de prueba e hice el siguiente codigo:
Código Delphi
[-]
procedure TDM.DataModuleCreate(Sender: TObject);
Var BaseDeDatos: String;
IniFile: TIniFile;
begin
IniFile := TIniFile.Create(ExtractFilePath(Application.ExeName)+'BDatos.ini');
BasedeDatos := IniFile.ReadString('BD','Path','');
If BasedeDatos = '' then
ShowMessage('Error al cargar Base de Datos') else
Begin
Try
BaseGeneral.DatabaseName := BaseDeDatos;
BaseGeneral.Connected := True;
Transaccion.Active := True;
Clientes.Open;
IBEvents1.Events.Clear;
IBEvents1.Events.Add('new_reg');
IBEvents1.RegisterEvents;
Except
ShowMessage('No se puede conectar el servidor...');
End;
End;
end;
procedure TDM.IBEvents1EventAlert(Sender: TObject; EventName: string;
EventCount: Integer; var CancelAlerts: Boolean);
begin
if EventName = 'new_reg' then
Begin
ShowMessage('Se inserto registro nuevo');
SClientes.DataSet.Refresh;
End;
end;
El tema es que para probar que se refrescaba correctamente copie el mismo programa a otra Pc de la red y ejecute ambos a la vez. El hecho es que si esta así como el código que puse la pc que ejecuta segunda se queda como pensando y pensando y pensando y..... en tanto si comento las lineas del IbEvents se ejecutan correctamente. Evidentemente algo no hago bien con este componente.
Ahora la pregunta. ¿Como usar el componente IbEvents?. Se coloca en cualquier lugar del programa?. Va en el form principal? en el DataModule?. Esta bien armado?, Que le falta?.
Gracias y saludos.-