Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > Varios
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Grupo de Teaming del ClubDelphi

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 24-10-2004
Mario1980 Mario1980 is offline
Miembro
 
Registrado: oct 2004
Posts: 75
Poder: 20
Mario1980 Va por buen camino
Question CAmpos de dbGRid

Hola tengo un dbgrid al que le agrego datos en uno de los campos de la tabla se ingresan numeros, lo que necesito es que cuando ingreso un valor en este campo si el valor ingresado ya existe en la tabla me mande un mensaje de error advirtiendo del problema yque no me deje ir de ese campo hasta que ingrese un valor correcto.
Muchas gracias para quien me ayude.
Responder Con Cita
  #2  
Antiguo 24-10-2004
Avatar de marcoszorrilla
marcoszorrilla marcoszorrilla is offline
Capo
 
Registrado: may 2003
Ubicación: Cantabria - España
Posts: 11.221
Poder: 10
marcoszorrilla Va por buen camino
Pues no tienes más que indexar por este campo con clave única y el propio motor de la base de datos lanzará un error en este caso y no te dejará seguir hasta que teclees otro número o canceles el actual.

Un Saludo.
__________________
Guía de Estilo de los Foros
Cita:
- Ça c'est la caisse. Le mouton que tu veux est dedans.
Responder Con Cita
  #3  
Antiguo 26-10-2004
Mario1980 Mario1980 is offline
Miembro
 
Registrado: oct 2004
Posts: 75
Poder: 20
Mario1980 Va por buen camino
Talking imposible

Hola, eso que decis de indexar la tabla no se puede.
Te explico porque:
Tengo una tabla maestra y otra detalle, por cada fila de la maestra muestra un contenido en la de detalle, por ejemplo linea 1 de la tabla maestra en la de detalle muestra en la columna que tiene numeros... 1,2,3
linea 2 de la maestra en la detalle muestra 1, 2.
por eso no puedo indexar, tengo que hacer que para cada linea del maestro no se repita el numero en la de detalle.
Espero haber sido mas claro y gracias!
Responder Con Cita
  #4  
Antiguo 26-10-2004
[basti] basti is offline
Miembro Premium
 
Registrado: ago 2004
Posts: 388
Poder: 20
basti Va por buen camino
Hola.

Si tu motor de base de datos admite BookMarks, podrías guardar la posición, comprobar si el número existe mediante locate y en caso de que exista mostrar el mensaje de error y borrarlo.

Otra solución sería utilizar el evento onValidate del campo que quieres comprobar, pero tendrías que clonar la tabla para poder comprobar que el valor ya existe.

un saludo
Responder Con Cita
  #5  
Antiguo 26-10-2004
Mario1980 Mario1980 is offline
Miembro
 
Registrado: oct 2004
Posts: 75
Poder: 20
Mario1980 Va por buen camino
Talking hola

les agradezco su ayuda pero una pregunta es recomendable clonar una tabla para verificar un dato?, si la tabla tuviera 500 o 1000 datos... valdria la pena?.
Saludos si se les ocurre otra cosa, por favor ayuda, estoy escribiendo esto de rodillas!!!!
Responder Con Cita
  #6  
Antiguo 26-10-2004
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
Me parece que la respuesta de marcoszorrilla puede aplicarse a tu caso. Lo único que necesitas es crear un índice único en la tabla detalle que se forme con la llave de la tabla maestra y el campo que te interesa:

maestra = (id, ... )
detalle = (id, maestra_id, numero, ... )

Si creas un índice único en detalle formado por los campos maestra_id y numero, entonces, para una misma línea de la tabla maestra, el valor en el campo numero de la tabla detalle no podrá repetirse.

Todo esto es mucho más eficiente ya que será el mismo motor de bases de datos el encargado de detectar las repeticiones.

// Saludos
Responder Con Cita
  #7  
Antiguo 29-10-2004
Mario1980 Mario1980 is offline
Miembro
 
Registrado: oct 2004
Posts: 75
Poder: 20
Mario1980 Va por buen camino
Talking Hola

Esa solucion ya se me habia ocurrido, pero... no existe otra solucion?
porque estas mismas tablas son usadas en otro lenguaje llamado Paradox y en este programa funcionan bien, solo queria saber si existe una solucion para ejecutar cuando el programa este corriendo, sin modificar tablas.
Gracias!!!!
Responder Con Cita
  #8  
Antiguo 30-10-2004
Mario1980 Mario1980 is offline
Miembro
 
Registrado: oct 2004
Posts: 75
Poder: 20
Mario1980 Va por buen camino
Unhappy hola

Se me olvido decir que uso delphi 2, por favor AYUDA!!!!!!!!!
Responder Con Cita
  #9  
Antiguo 31-10-2004
Avatar de Lepe
[Lepe] Lepe is offline
Miembro Premium
 
Registrado: may 2003
Posts: 7.424
Poder: 28
Lepe Va por buen camino
Espero que en Delphi2 esté el Lookup :
Código Delphi [-]
if Vartype( tabla.Lookup('nombreCampo', ValorqueTieneElcampo,'Campoquehadedevolver')) in [varNull] then
 // pues no existe ese valor en la tabla
else
  // pos si que existe cuñao

añade Uses Variants;

Saludos

Última edición por Lepe fecha: 31-10-2004 a las 02:02:52. Razón: el uses
Responder Con Cita
  #10  
Antiguo 31-10-2004
Mario1980 Mario1980 is offline
Miembro
 
Registrado: oct 2004
Posts: 75
Poder: 20
Mario1980 Va por buen camino
gracias

Gracias Lepe intentare implementar esto. y .. Que viva España!, si sos español, que se yo.
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 17:42:34.


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