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 02-07-2005
Patricio Patricio is offline
Miembro
 
Registrado: jul 2004
Posts: 433
Poder: 20
Patricio Va por buen camino
no tengo ninguna clave pero me dice que se repite

Hola vuelvo a molestarlos por una pequeña inquietud

Tengo una tabla con 5 campos, pero ninguno esta definido como clave, porque es una tabla que uso como auxiliar. Ahora si me agrega a dos registros con el mismo valor en el campo CODIGO (este campo lo utilizo como clave en otras tablas relacionadas) me dice cuando los quiero borrar que no puede porque encontro registros duplicados, esto le paso a alguno? Saludos
Responder Con Cita
  #2  
Antiguo 02-07-2005
Avatar de mamcx
mamcx mamcx is offline
Moderador
 
Registrado: sep 2004
Ubicación: Medellín - Colombia
Posts: 3.911
Poder: 25
mamcx Tiene un aura espectacularmamcx Tiene un aura espectacularmamcx Tiene un aura espectacular
Una leccion: TODA TABLA DEBE TENER UN CAMPO CLAVE. Punto. Definele un campo Id autonumerico.

El porque te pasa el error es muy simple.... resulta que en la tabla esta estos datos

Nombre Apellido
Mario Montoya
Mario Montoya

Y visualmente en el grid tienes lo mismo

Nombre Apellido
Mario Montoya
Mario Montoya

Ahora, visualmente, haces esto:

Nombre Apellido

Mario Montoya

Y el componente obviamente hace esto:

DELETE FROM Nombres WHERE Nombre='Mario' AND Apellido='Montoya'

PERO VISUALMENTE es UNA SOLA FILA la que se borro, Y FISICAMENTE estas ejecutando una sentencia que borra DOS filas... cual de las dos, la primera o la segunda se debe borrar? Asi que como los programadores de las interfaces de datos saben que no pueden adivinar por vos, te sacan un lindo mensaje de error es un error de logica no de datos. De hecho si manualmente ejecutas el DELETE no te saca el error porque explicitamente estas dando la orden y se supone, sabes lo que haces.

Es por eso, que la unica forma que hay para que la accion visual sea = a la fisica es:

Id Nombre Apellido
1 Mario Montoya
2 Mario Montoya

Porque ahora si borras la primera fila, la accion es clara. De pronto si vienes de motores de escritorio como Fox o Paradox no pasaba esto ya que existe un ID intrinseco que es:

RecNo Nombre Apellido
1 Mario Montoya
2 Mario Montoya

lo cual resolvia el problema...
__________________
El malabarista.
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 06:39:36.


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