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 24-05-2005
manu manu is offline
Miembro
 
Registrado: may 2003
Posts: 25
Poder: 0
manu Va por buen camino
Lightbulb Borra registros duplicados en tabla ACCES

Hola a todos.
Tengo el siguiente problema:
Estoy intentando borrar de una base de datos todos los registros duplicados con el siguiente codigo:

//borrar duplicados.
Código Delphi [-]
procedure TForm1.Button3Click(Sender: TObject);
  begin
     AdoQuery2.Prior;
     AdoQuery2.Edit;
  While not AdoQuery2.Eof DO begin
        P1:= AdoQuery2.FieldByName('Referencia').AsString;
        AdoQuery2.Next;
        while  P1= AdoQuery2.FieldByName('Referencia').AsString do begin
           AdoQuery2.DeleteRecords( arCurrent);
           AdoQuery2.Next;
        end;
  end;
  end;
Pero cuando lo ejecuto me da el siguiente error:
Informacion de la columna clave insuficiente o incorrecta, demasiadas filas para la actualizacion;

¿Alguien me puede hechar una mano?.

¿Se podria hacer de otra forma?

Saludos...

Última edición por marcoszorrilla fecha: 24-05-2005 a las 21:37:17.
Responder Con Cita
  #2  
Antiguo 24-05-2005
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
Tienes que tener una clave única en la tabla, aunque sea un campo autoincremental.

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 24-05-2005
Avatar de vtdeleon
vtdeleon vtdeleon is offline
Miembro
 
Registrado: abr 2004
Ubicación: RD & USA
Posts: 3.236
Poder: 24
vtdeleon Va por buen camino
Saludos
Código SQL [-]
select CAMPO
  FROM tabla WHERE campo In (SELECT campo FROM 
  tabla As Tmp GROUP BY campo HAVING Count(*)>1)

Esta sentencia, te devuelve los registros repetidos. Creo con un arreglito puede puedes hacer lo que pides, sin tener que hacer dos bucles.
__________________
Van Troi De León
(Not) Guía, Code vB:=Delphi-SQL, ¿Cómo?
Viajar en el tiempo no es teóricamente posible, pues si lo fuera, ya estarían aqui contándonos al respecto!
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 18:43:32.


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