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 22-06-2004
JOMABRI JOMABRI is offline
Miembro
 
Registrado: may 2004
Posts: 30
Poder: 0
JOMABRI Va por buen camino
Post Validacion llave con ClientDataset

Hola foro, estoy actualizando 1 tabla de ciudades(codigo y nombre), la llave es el codigo. utilizo en query dbexpress, DataSetProvider, ClientDataSet y 1 Grid.

Anteriormente cuando el usuario digitaba codigos duplicados en el ClientDataSet, salia error de KEY VIOLATION, pero no se que parametro modifique por error y ya el error no me sale. Que debo hacer para que me valide de nuevo??


Gracias.
Responder Con Cita
  #2  
Antiguo 23-06-2004
Avatar de guillotmarc
guillotmarc guillotmarc is offline
Miembro
 
Registrado: may 2003
Ubicación: Huelva
Posts: 2.638
Poder: 24
guillotmarc Va por buen camino
Hola.

Verifica que la llamada a ApplyUpdates la haces con el parámetro 0 y no -1.

Saludos.
__________________
Marc Guillot (Hi ha 10 tipus de persones, els que saben binari i els que no).
Responder Con Cita
  #3  
Antiguo 23-06-2004
JOMABRI JOMABRI is offline
Miembro
 
Registrado: may 2004
Posts: 30
Poder: 0
JOMABRI Va por buen camino
Gracias Marc, pero no es en el applyUpdates. Es asi:

En el grid y ClientDataSet Tienes:

Codigo Nombre
1 Madrid


Y digitas en nuevo registro con el codigo 1 quedando el grid asi:

Codigo Nombre
1 Madrid
1 Barca

Cuando doy TAB en el campo nombre del segundo registro, me debe generar una excepcion de KEY VIOLATION.



Gracias.


Cita:
Empezado por guillotmarc
Hola.

Verifica que la llamada a ApplyUpdates la haces con el parámetro 0 y no -1.

Saludos.
Responder Con Cita
  #4  
Antiguo 23-06-2004
Avatar de guillotmarc
guillotmarc guillotmarc is offline
Miembro
 
Registrado: may 2003
Ubicación: Huelva
Posts: 2.638
Poder: 24
guillotmarc Va por buen camino
Hola.

Pero es que el Key Violation es una excepción que se provoca en la base de datos, y al insertar un registro en el ClientDataset, no se envia a la base de datos hasta que no se llame al ApplyUpdates (momento en el que puede saltar esta excepción).

Para lo que quieres hacer, creo que tendrias que poner un ApplyUpdates en el evento AfterPost del ClientDataset. De esta forma cada vez que das de alta un registro, lo envias automaticamente a la base de datos, con lo que se comprueban la unicidad de los índices y puede saltar esa excepción.

Saludos.
__________________
Marc Guillot (Hi ha 10 tipus de persones, els que saben binari i els que no).
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 08:11:49.


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