Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Bases de datos > MS SQL Server
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 18-01-2006
jam888 jam888 is offline
Miembro
 
Registrado: sep 2004
Posts: 115
Poder: 20
jam888 Va por buen camino
Question Eliminar Duplicados ¿?

Estimada gente del foro, espero se encuentren bien, yo en un pequeño problema, tengo una base de datos de sql server y en ella una tabla autores en la cual en el campo nombre tengo autores repetidos de la siguiente manera:

Codigo Nombre
1 Pablo Garcia
2 Pablo Garcia
3 Pablo Garcia
4 Pablo Garcia
5 Arce Raul
6 Arce Raul
7 Arce Raul
. .
. .
. .
y siguen repitiendose, lo que quiero hacer es dejar por ejemplo un solo Pablo Garcia y un solo Arce Raul es decir borrar los duplicados, que debo hacer por que no encuentro solucion .
Un Abrazo
Responder Con Cita
  #2  
Antiguo 18-01-2006
Avatar de Neftali [Germán.Estévez]
Neftali [Germán.Estévez] Neftali [Germán.Estévez] is offline
[becario]
 
Registrado: jul 2004
Ubicación: Barcelona - España
Posts: 18.282
Poder: 10
Neftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en bruto
No se si debes hacerlo desde SQL Server o desde Delphi.
En ambos casos una solución sencilla (sea utilizando un Stored Procedure o código Delphi), es crear una tabla igual que ésta, añadirle un índice único por el campo nombre y luego programar el proceso que te pase todos los registros desde la tabla 1 a la 2.
Al haber definido un índice único en la segunda tabla todos los repetidos generarán error, es cuestión de capturar ese error y omitirlo (revisa @@error).

Sin más información, no se si es esto a lo que te refieres.
__________________
Germán Estévez => Web/Blog
Guía de estilo, Guía alternativa
Utiliza TAG's en tus mensajes.
Contactar con el Clubdelphi

P.D: Más tiempo dedicado a la pregunta=Mejores respuestas.
Responder Con Cita
  #3  
Antiguo 18-01-2006
Avatar de delphi.com.ar
delphi.com.ar delphi.com.ar is offline
Federico Firenze
 
Registrado: may 2003
Ubicación: Buenos Aires, Argentina *
Posts: 5.932
Poder: 27
delphi.com.ar Va por buen camino
Código SQL [-]
DELETE FROM TABLA T1
WHERE CODIGO <> (SELECT MIN(CODIGO) 
                   FROM TABLA T2
                  WHERE T1.NOMBRE = T2.NOMBRE)

Saludos!
__________________
delphi.com.ar

Dedique el tiempo suficiente para formular su pregunta si pretende que alguien dedique su tiempo en contestarla.
Responder Con Cita
  #4  
Antiguo 18-01-2006
Avatar de ContraVeneno
ContraVeneno ContraVeneno is offline
Miembro
 
Registrado: may 2005
Ubicación: Torreón, México
Posts: 4.738
Poder: 23
ContraVeneno Va por buen camino
Creo que este mensaje se refiere a lo mismo.
__________________

Responder Con Cita
  #5  
Antiguo 07-06-2012
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
Cita:
Empezado por delphi.com.ar Ver Mensaje
Código SQL [-]
DELETE FROM TABLA T1
WHERE CODIGO <> (SELECT MIN(CODIGO) 
                   FROM TABLA T2
                  WHERE T1.NOMBRE = T2.NOMBRE)
Hombre, muchas gracias Federico, me sirvió mucho.

// Saludos
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

Temas Similares
Tema Autor Foro Respuestas Último mensaje
Eliminar Registro (Validar) UTECYBER OOP 8 29-10-2008 18:15:13
Duplicados con LEFT OUTER JOIN Cabanyaler MS SQL Server 11 17-11-2005 08:46:23
eliminar opcion de eliminar en un dbgrid morfeo21 Varios 3 14-07-2005 17:05:32
Problema con duplicados ignasi Tablas planas 1 25-05-2004 02:57:55
Eliminar Registros Duplicados ? Jvilomar Firebird e Interbase 14 16-03-2004 22:14:35


La franja horaria es GMT +2. Ahora son las 08:45:30.


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