Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   Conexión con bases de datos (https://www.clubdelphi.com/foros/forumdisplay.php?f=2)
-   -   enviar mensajes de error en campos obligatorios y clave unica (https://www.clubdelphi.com/foros/showthread.php?t=43600)

Goyo 15-05-2007 23:11:07

enviar mensajes de error en campos obligatorios y clave unica
 
Referente al hilo que hizo Marcoszorrilla ver hilo original, quisiera saber donde poner estos procedimiento, dentro de que parte de mi codigo, para ello les comento que tengo 5 tablas, TEmpleados, TDepartamentos, TDirecciones, TEspecialidades, y TPuestos; ademas tengo un modulo "DM"

es precisamente lo que necesito, solo que no se donde ponerlo (en que parte de mi codigo)

Cita:

Procedure midberror(DataSet: TDataSet; E: EDatabaseError);
//…….
Const
eKeyViol = 9729;
eRequiredFieldMissing = 9732;
eForeignKey = 9733;
eDetailsExist = 9734;
eSqlGralerror = 13059;
eInvalidTime = 10058;
eInvalidDate = 75;
EinvalidDateTime=10060;
eRegisterLocked= 10241;

//implementation
//……

Procedure midberror(DataSet: TDataSet; E: EDatabaseError);
var
mierror:double;
begin
mierror:= (E as EDBEngineError).Errors[0].Errorcode;

if (E is EDBEngineError) then
if (E as EDBEngineError).Errors[0].Errorcode = eKeyViol then
begin
Application.MessageBox('Imposible dar alta ese registro ya existe','Atención',mb_Ok +
mb_IconQuestion);
Abort;
end;

if (E as EDBEngineError).Errors[0].Errorcode = eRequiredFieldMissing then
begin
Application.MessageBox('Imposible dar alta hay un campo vacio.','Atención',mb_Ok +
mb_IconQuestion);
Abort;
end;

if (E as EDBEngineError).Errors[0].Errorcode = eInvalidTime then
begin
Application.MessageBox('Formato de hora incorrecto.','Atención',mb_Ok +
mb_IconQuestion);
Abort;
end;

if (E as EDBEngineError).Errors[0].Errorcode = eInvalidDate then
begin
Application.MessageBox('Formato de fecha incorrecto.','Atención',mb_Ok +
mb_IconQuestion);
Abort;
end;

if (E as EDBEngineError).Errors[0].Errorcode = eInvalidDateTime then
begin
Application.MessageBox('Formato de fecha-hora incorrecto.','Atención',mb_Ok +
mb_IconQuestion);
Abort;
end;

//campo en blanco
if (E as EDBEngineError).Errors[0].Errorcode = eSqlGralerror then
begin
Application.MessageBox('Imposible dar alta hay un campo requerido vacío.','Atención',mb_Ok +
mb_IconQuestion);
Abort;
end;

//Registro bloqueado
if (E as EDBEngineError).Errors[0].Errorcode = eRegisterLocked then
begin
Application.MessageBox('Imposible hacer modificaciones registro bloqueado por otro usuario.','Atención',mb_Ok +
mb_IconQuestion);
Abort;
end;

end;

//aqui capturamos el error de bloqueo
procedure TdmoPalma.CliEditError(DataSet: TDataSet; E: EDatabaseError;
var Action: TDataAction);
begin
midberror(cli,e);
end;

procedure TdmoPalma.CliPostError(DataSet: TDataSet; E: EDatabaseError;
var Action: TDataAction);
begin
midberror(cli,e);
end;
Las tablas las tengo en paradox y no trabaja en red


La franja horaria es GMT +2. Ahora son las 14:18: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