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 16-10-2003
viajero2015 viajero2015 is offline
Miembro
 
Registrado: sep 2003
Ubicación: Cuba
Posts: 47
Poder: 0
viajero2015 Va por buen camino
como crear exception para validar duplicación de llaves en tabla

Hola amigos.
como puedo crear una exception para poder validar una duplicación de una llave en una tabla en que evento de la misma puedo validar dicho caso.

Gracias por su ayuda
Responder Con Cita
  #2  
Antiguo 16-10-2003
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
El mismo método Post de TTable se encarga de lanzar una excepción ante una duplicación de llave. Si quieres controlar la excepción podrías usar algo como:

Código:
try
  Table.Post;
except
  { código para manejar la excepción }
end;
// Saludos
Responder Con Cita
  #3  
Antiguo 17-10-2003
Avatar de Lepe
[Lepe] Lepe is offline
Miembro Premium
 
Registrado: may 2003
Posts: 7.424
Poder: 28
Lepe Va por buen camino
esto te vale fijo


Saludos.
Responder Con Cita
  #4  
Antiguo 18-10-2003
viajero2015 viajero2015 is offline
Miembro
 
Registrado: sep 2003
Ubicación: Cuba
Posts: 47
Poder: 0
viajero2015 Va por buen camino
Hola gracias por al yudas d euds, hice eso con try except y trabajo, y vi la otra solucion pero por lo que vi e spara una base datos paradox y yo trabajo con uan base datos mdb, no habra diferencias?, ahora si quiero saber cual fue el código de error, pues pueds er que la clave principal la deje vacia o puede ser que ya este adicionado esa llave en la tabla, ahora como puedo yo saber el codifo que genero esa exception?.


saludos y gracias TOMAS
Responder Con Cita
  #5  
Antiguo 20-10-2003
Avatar de Lepe
[Lepe] Lepe is offline
Miembro Premium
 
Registrado: may 2003
Posts: 7.424
Poder: 28
Lepe Va por buen camino
esos errores te los pilla si usas BDE para el acceso a las tablas, que usas tu ? ADO ?
Responder Con Cita
  #6  
Antiguo 20-10-2003
viajero2015 viajero2015 is offline
Miembro
 
Registrado: sep 2003
Ubicación: Cuba
Posts: 47
Poder: 0
viajero2015 Va por buen camino
Thumbs down

Yo uso ADO, pero ya me trabajo era que no sabia los codigos de errores pero ya, ahora estoy trabajndo en en el evento OnDeleteError que es para cuando s eva eliminar y s eproduce un error digamos cuando hay una tabla relacionada hija o sea de uno a mucho.

alquine me pudiera explicar la difernecia entre los tipos de accesoa datos que tiene delphi, digamos
ADO,BDE, IDBexplorer etc etc.
Gracias TOMAS
Responder Con Cita
  #7  
Antiguo 21-10-2003
Avatar de Cabanyaler
Cabanyaler Cabanyaler is offline
Miembro
 
Registrado: jun 2003
Ubicación: País Valencià
Posts: 339
Poder: 21
Cabanyaler Va por buen camino
Yo lo hago de este modo:

// El post, lo protejo con una excepcion
try
DM.Tb.Post;
except
on E: EDBEngineError do // Ctrl de la Key Violation
begin
// Entro aqui pq se ha producido un error de clave duplicada
MessageDlg ('Posible clave DUPLICADA', mtError, [mbYes], 0);
end
else
begin
MessageDlg ('Error GENERAL en la Base de datos',[mbYes], 0);
end
end; // Del try
__________________
El meu país és tan petit, que des de dalt d'un campanar es pot veure el campanar veí.
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 00:19:20.


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