![]() |
![]() |
| Paypal | FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
|||||||
| Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Buscar | Temas de Hoy | Marcar Foros Como Leídos |
![]() |
|
|
Herramientas | Buscar en Tema | Desplegado |
|
|
|
#1
|
||||
|
||||
|
Los registros son identicos, o son "duplicados" solo en los campos que te interesa establecer como llave??
Si es asi, cual es la diferencia de los otros campos cual de ellos te interesa conservar??
__________________
Juan Antonio Castillo Hernández (jachguate) Guía de Estilo | Etiqueta CODE | Búsca antes de preguntar | blog de jachguate |
|
#2
|
|||
|
|||
|
Hola Juan......
Mira esta es la Estructura Mas o menos de lo que quiero hacer Tabla1 c1,C2,C3 donde c1 y c2 son mis campos claves C1 C2 C3 1 1 a 1 2 b 1 3 c 2 4 d 2 5 e Entonces solo me gustaria quedarme en este caso con solo dos registros 1 y 2 del campo c1.....
__________________
El conocimiento es un Patrimonio Universal.... |
|
#3
|
||||
|
||||
|
Hola.
Puedes hacer un pequeño programa en Delphi, que recorra la tabla (ordenada por C1), de forma que elimine todos los registros con el mismo código. Código:
procedure Limpiar;
var Codigo: integer;
begin
qryTabla.Open;
Codigo := -1;
while not qryTabla.eof do begin
if qryTabla.FieldValues['C1'] = Codigo then begin
qryTabla.Delete;
end
else begin
Codigo := qryTabla.FieldValues['C1']
end
qryTabla.Next;
end;
qryTabla.Close;
end;
Saludos.
__________________
Marc Guillot (Hi ha 10 tipus de persones, els que saben binari i els que no). |
|
#4
|
|||
|
|||
|
Gracias .... Pero utilize el codigo que me has facilitado y no pasa nada.... incluso lo conecte con un grid y cuando ejecuto el procedimiento parece como si estuviera leyendo la tabla pero no pasa nada.....
Todos los registros aun siguen ahi.... yo tenia ese mismo problema con unos registros en SQLServer y encontre un Scrip que me permitio solucionar el problema...pero parece que el Standar de Interbase no lo soporta... aqui esta el codigo a ver si me das una manita. delete from a from cust_tran a join (select cust_id, max(tran_date) max_tran_date from cust_tran group by cust_id having count(*) > 1) b on a.cust_id = b.cust_id and a.tran_date < b.max_tran_date Gracias por Todo
__________________
El conocimiento es un Patrimonio Universal.... |
|
#5
|
||||
|
||||
|
Hola.
El código que te pasé es muy sencillo. El problema puede estar en algo específico de los componentes que utilizes. ¿ Por ejemplo, si tus componentes utilizan una transacción, la confirmas al final ?. Esta consulta es dificil de adaptar a Interbase/Firebird. En es fácil hacerlo mediante una construcción for select .... do en un procedimiento almacenado. Puedes consultar el manual de Interbase/Firebird para consultar la sintaxis exacta de esta construcción. Saludos.
__________________
Marc Guillot (Hi ha 10 tipus de persones, els que saben binari i els que no). |
|
#6
|
|||
|
|||
|
Hola Marc....Gracias por ayudarme.....
con la instruccion For Select.... do se me ha ocurrido una idea (excusenme pero es que no soy muy diestro aun en este asunto de Interbase) a ver si me ayudas... para poder eliminar los registros sobrantes podria ejecutar un SP para ir eliminandolos uno por uno hasta que la coleccion de registro sea solo uno dandole como parametro el mismo codigo asi el algoritmo seria: para la seleccion campo1,campo2 desde miTabla donde campo1 = :Parametro dentro :Campo1,:Campo2 Hacer Comienza Elimina desde miTabla donde Campo1 = :Campo1 y Campo2 = :Campo2 Finaliza Ahora el punto es crear un procedimiento para llamar los registros por grupos repetidos e ir eliminandolos hasta que solo quede uno en la Tabla... luego seguir con el siguiente grupo y asi suceviamente......se que suena un poco raro.... pero esa es la idea...
__________________
El conocimiento es un Patrimonio Universal.... |
|
#7
|
||||
|
||||
|
Hola.
Tiene alguna clave primaria tu tabla. Si me indicas cual es la clave primaria, te ayudo con el procedimiento almacenado para solventar el problema. Saludos.
__________________
Marc Guillot (Hi ha 10 tipus de persones, els que saben binari i els que no). |
![]() |
| Herramientas | Buscar en Tema |
| Desplegado | |
|
|
|