Inicio » Oracle » SQL » Como eliminar registro duplicados en Oracle

Como eliminar registro duplicados en Oracle

Método 1:

SQL> DELETE FROM table_name A WHERE ROWID > (
  2    SELECT min(rowid) FROM table_name B
  3    WHERE A.key_values = B.key_values);

Se pueden borrar todos los rowids mayores o menores que el valor dado.

Método 2:

SQL> create table table_name2 as select distinct * from table_name1;
SQL> drop table table_name1;
SQL> rename table_name2 to table_name1;

Este método suele ser más rápido, pero hay que recrear todos los indexes, constraints, triggers, etc.

Método 3:

SQL> delete from my_table t1
SQL> where  exists (select 'x' from my_table t2
SQL>                 where t2.key_value1 = t1.key_value1
SQL>                   and t2.key_value2 = t1.key_value2
SQL>                   and t2.rowid      > t1.rowid);

Si se comparan columnas not null se tiene que utilizar la función NVL, ya NULL no es igual a NULL

Método 4:

SQL>DELETE  FROM EMP 
SQL>WHERE ('DELETE',SAL)  IN (
SQL>             SELECT CASE WHEN COUNT(*)>1 THEN 'DELETE' ELSE 'NO' END DELETEFLAG ,SAL 
SQL>                  FROM EMP 
SQL>                  GROUP BY SAL 
SQL>                  HAVING COUNT(*)>1)

Método 5:

SQL>DELETE table_name
SQL>WHERE  rowid IN
SQL>       ( SELECT LEAD(rowid) OVER
SQL>                (PARTITION BY key_values ORDER BY NULL)
SQL>         FROM   table_name );

8 pensamientos en “Como eliminar registro duplicados en Oracle

  1. muchas gracias por compartir tu conocimiento… después de varios cabezazos por no poder borrar registros duplicados encontré tu página….

Responder

Introduce tus datos o haz clic en un icono para iniciar sesión:

Logo de WordPress.com

Estás comentando usando tu cuenta de WordPress.com. Cerrar sesión / Cambiar )

Imagen de Twitter

Estás comentando usando tu cuenta de Twitter. Cerrar sesión / Cambiar )

Foto de Facebook

Estás comentando usando tu cuenta de Facebook. Cerrar sesión / Cambiar )

Google+ photo

Estás comentando usando tu cuenta de Google+. Cerrar sesión / Cambiar )

Conectando a %s