Delete Duplicate Rows?
Feb 6, 2011I having a problem with duplicate rows with a query.  
What I have so far is
SELECT D.Student_Id,
E.Latest_Reg_Date,
E.Attendance_Count,
[Code].....
I having a problem with duplicate rows with a query.  
What I have so far is
SELECT D.Student_Id,
E.Latest_Reg_Date,
E.Attendance_Count,
[Code].....
I want to delete the duplicate rows in a table without using ROWID.
I have the following data.
SNO  SNAME SECTION
1    RAM     A
2    SHYAM   B
2    SHYAM   B
3    KISHOR  C
3    KISHOR  D
4    RAMESH  E
5    RAJESH  F
5    RAJESH  F
The Output Should be like this.
SNO  SNAME SECTION
1     RAM     A
2     SHYAM   B
3     KISHOR  C
3     KISHOR  D
4     RAMESH  E
5     RAJESH  F
I have a requirement to delete duplicate records. For example,if the below query retrieves count of duplicate records along with the column values.  
select col2,col3,col4,col5,col6,col7,count(*) from table
group by
col2,col3,col4,col5,col6,col7 
having count(*) > 1;
I would like to retain only one record with max(col1) which is a surrogate key and other records should be deleted.How to retain one record in a duplicate record set based on max of certain column.
say I have duplicate records in TABLE3, can I use following SQL to delete the duplicates?FYI, BUS_FID is unique number column.
TABLE3
------------------------
ori_id*************id***********r_f_a****r_t_a*******bus_id
72840000040572*****740040572****255******267*********1
72840000040572*****740040572****255******267*********2
2840000040572******20040572*****25*******27**********3
7840000040572******70040572*****2********6***********4
DELETE FROM TABLE3 WHERE BUS_ID NOT IN (SELECT MIN(BUS_ID) FROM TABLE3 GROUP BY ORI_ID);
consider TABLE3 has millions of millions of data, say 40 millions.Update, I have tried it and it is very slow... 
In oracle 9i ........How to delete duplicate entries in a table ?
if suppose in a table named office, one or more entry(row) is repeated more then twice or minimum twice.
I need a query to delete the multiple entries ....
Note:
--->No constraints applied on the table.
--->No Primary Key
--->You cannot create any object....that is no view or a duplicate table can be created
I need to delete duplicate records from a table (indeed they are multiple duplicates).
Table Data
IDGroupQty
1KK30
1KK0
1KK19
2AA0
2AA30
3AA0
3AA30
3AA30
3AA9
My aim is to delete duplicates out of above data, with the below condtions.
1) first record with value 30 and then with value 0.
2) if there are 3 duplicate records ex: ID is 1 and Group KK, then i have to delete both 30 & 0 qty records.
3) If there are more than 3 duplicate records ex: ID is 3 and Group is AA, the i have to delete all the records with qty value either 30 or 0 and.
I have written a query like below.
SELECT   id,
         unit,
         RANK ()
            OVER (PARTITION BY id, unit
                  ORDER BY id, unit)
            num                                                  
  FROM   temp;
with the above query, i am unable to mark this dynamic duplications.
How can i delete duplicate records from the table.
View 2 Replies View RelatedI have written this below code. The logic behind the code is, Delete the duplicate record from a table, and delete those record from other 7 table based on the SL_NUMBER.
But Problem is After delete the duplicate record When I have use Below statement
 RETURNING SL_NUMBER BULK COLLECT INTO rec_sl_number;
This statement unable to return approx 40 Lakhs SL_NUMBER
DECLARE
rec_sl_number dbms_sql.number_table;
BEGIN
[Code]....
I have a table like this
table:
id name   plan   code 
1   sam  normal   5
1   sam  normal   6
1   sam  special  5
1   sam  Special  6
I need to delete data in such a way that one entry with normal and one entry with special plan should remain and should be with different code. Does not matter whether normal stays with 5 or 6 code.
I tried with rowid but it deletes either both normal or both special or returns same code for normal and special.
I want to delete the duplicate records from a table without using Below 2 methods: 
1> delete from table_1 a where row_id not in (select  min(row_id) from Table_1 b where a.PK=b.PK);
2> Insert into Table_2 select distinct * from  Table_1;
Drop table Table_1;
Rename Table_2 to Table_1;
how to delete duplicated records from a table without using row_id. I found the duplicated rows from a table using Analytical Function. But i could not use the Analytical function in the where condition. 
My table(tab2) Structure is 
   DEPTNODEPT_NAMEEMPIDSEXID1
107jadf         1F1
40asdf         55
10purchase 2M2
10sales         3M3
30HR         4F4
I found the Duplicate Record by using the query
 with a as
  (select deptno,dept_name,empid,sex,id1,row_number()over(partition by deptno order by deptno) rnum from tab2)
select * from a where rnum >1
how to delete duplicate record .
how i can chk & delete duplicate rows from a table
View 3 Replies View RelatedCreated three tables and group by 3 tables column name. want to delete duplicate record without first table(test). Delete the duplicate record in test1 and test2 except test. 
SELECT a as Name,b as M_Name, c as L_Name, count(*)  FROM ( SELECT first_name as a, middle_name as b, last_name as c FROM test UNION ALL  SELECT first_name as a, middle_name as b, last_name as c FROM test1 UNION ALL  SELECT first_name as a, middle_name as b, last_name as c FROM test2  ) as countGROUP BY a,b,cHAVING count(*) > 1
I have to eliminate duplicate pairs from the following data set.
for ex. Adney Vaughan  and Berkly Wassen appears in both AG1 and AG2. how can i get rid of these repititive rows?
  
AG1  ----------- AG2    
Acton Wibert  ----  Currier Barhydt 
Adney Vaughan  --- Luella Edmund    
Adney Vaughan  --- Berkly Wassen    
Alden Anstruther  --- Courtney Gavet 
Ashley Alvord  --- Saunders Buel  
Aswin Wilbraham  --- Dale Cooper    
Barnum Sears  --- Grayson Lightfoot 
Berkly Wassen  --- Luella Edmund    
Berkly Wassen  --- Adney Vaughan
Bersh Musgrave  --- Derward Knight  
Berthilda Darrell  --- Broderick Reynold 
Broderick Reynold  --- Berthilda Darrell
getting sql query to get the result below.If the Key repeats then I need to set it to O if for each key New_link doesnot match.
My Present table
Key New_Link
1   4
3   2
3   5
5   1
5   1
RESULT
Key New_Link
1     4
3     0
5     1
removing duplicate rows from a table.
We have the following table:
SSD@ermd> desc person_pos_history
Name                                                                     Null?    Type
------------------------------------------------------------------------ -------- ------------------------
PERSON_POSITION_HISTORY_ID                                               NOT NULL NUMBER(10)
POSITION_TYPE_ID                                                         NOT NULL NUMBER(10)
PERSON_ID                                                                NOT NULL NUMBER(10)
EVENT_ID                                                                 NOT NULL NUMBER(10)
USER_INFO_ID                                                                      NUMBER(10)
TIMESTAMP                                                                NOT NULL DATE
We found out that few person_id's are repeating for a particular event (3):
select PERSON_ID, count(*)
from person_pos_history
group by PERSON_ID, EVENT_ID
having event_id=3
     and count(*) > 1
order by 2
PERSON_ID   COUNT(*)
---------- ----------
    217045        356
    216993        356
    226198        356
    217248        364
[Code]...
If we look at the 1st person id "217045", we can see that it is repeating 356 times for event id 3.
SSD@ermd> select POSITION_ASSIGNMENT_HISTORY_ID, POSITION_TYPE_ID, PERSON_ID,EVENT_ID, to_char(timestamp, 'YYYY-MM-DD HH24:MI:SS')
  2  from person_pos_history
  3  where EVENT_ID=3
  4  and person_id=217045
  5  order by timestamp;
   PERSON_POSITION_HISTORY_ID  POSITION_TYPE_ID  PERSON_ID   EVENT_ID TO_CHAR(TIMESTAMP,'
------------------------------ ---------------- ---------- ---------- -------------------
                        222775               38     217045         03 2012-05-07 10:29:49
                        222774               18     217045         03 2012-05-07 10:29:49
                        222773                8     217045         03 2012-05-07 10:29:49
[Code]...
356 rows selected.It is safe to assume that the person id/event id with the earliest timestamp is the one that was loaded 1st, hence, the one we want to keep and the rest should be deleted.
sql to achieve the duplicate removal.
how to remove duplicate rows from table?
View 6 Replies View RelatedHow to retrieve duplicate rows from a table, suppose i don't know any column names. Without hard-coding column names I need to find.
View 5 Replies View RelatedI have two tables A and B
CREATE TABLE A(EMP_ID NUMBER, EMP_NAME VARCHAR2(100))
CREATE TABLE B(EMP_ID NUMBER, EMP_ATT1 VARCHAR2(10), EMP_ATT2 VARCHAR2(10))
INSERT INTO A VALUES(1, 'ONE');
INSERT INTO A VALUES(2, 'TWO');
INSERT INTO A VALUES(3, 'THREE');
[Code]....
This query returns all the matching row of A and B
SELECT A.EMP_ID, A.EMP_NAME, B.EMP_ATT1, B.EMP_ATT2
FROM A
INNER JOIN B ON A.EMP_ID=B.EMP_ID
The output for this shows:
EMP_ID    EMP_NAME         EMP_ATT1          EMP_ATT2
1             ONE            1ATT1               1ATT2
2             TWO            2ATT1               2ATT2
2             TWO            2ATT1.1             2ATT2.1
3             THREE          3ATT1               3ATT2
The requirement is to avoid duplicate rows even if matched:
EMP_ID    EMP_NAME         EMP_ATT1          EMP_ATT2
1             ONE            1ATT1               1ATT2
2             TWO            2ATT1               2ATT2
3             THREE          3ATT1               3ATT2
I am trying to find sum for one record for each partition but while taking that timestamp giving me bit trouble, i have tried to reproduce the table and some little data 
CREATE TABLE TEST_COUNT
(END_TIME        DATE 
,SUCCESSFUL_ROWS NUMBER
,FAILED_ROWS     NUMBER
,TBL_NAME        VARCHAR (4) 
,PARTITION_NAME  VARCHAR (240) )
[code]....
column sid format 'a5'
column serial# format 'a10'
column mins_running format 'a15'
column sql_text format 'a100'
set linesize 200
set pagesize 30
[Code]..
I am running this code, and the output shows multiple lines.
TRIM(S.SID)                              TRIM(S.SERIAL#)                          MINS_RUNNING    SUBSTR(Q.SQL_TEXT,1,70)
---------------------------------------- ---------------------------------------- --------------- ----------------------------------------------------------------
700                                      46592                                       242.08       Select count(*) as count, case when count(*)>0 then 'FAIL' else
700                                      46592                                       242.08       'PASS' end as result
                                                                                                  from (SELECT cv.code_value
                                                                                                  FROM code_valu
[Code]...
Is there a way to wrap up the column for SQL_TEXT VARCHAR2(64) so that I can 1 row for the output?
I am trying to write an sql which shows the running total for records which has duplicate. 
sample rows:
col1 col2 col3 
1      A    2
1      A    2
1      A    2
1      B    3
1      B    3
1      C    5
1      D    2
1      D    2o
p required:
col1 col2 col3  cumulative_tot
1      A    2       2
1      A    2       2
1      A    2       2
1      B    3       5
1      B    3       5
1      C    5       10
1      D    2       12
1      D    2       12
In a table i have some duplicate rows
I can get it through this query : select PARTY_ID from XXWFS_CUSTOMER_EXT group by PARTY_ID having count (PARTY_ID) > 1;
Now for the records which i got for each duplicate row i want to update the second row with a specific value.. so that duplicate rows does not exist anymore
Ex: I got party id's 12, 14, 16, 18 two times each
Now as 12 is two times.. i want to update the second row of 12 with some x value same is the case for other values like 14,16, etc
how can i write a procedure for this
I have a view and in that view i need to remove duplicate rows from output. For that i need to run select query in where clause of view if select query return true then we need to execute second condition.
my requirement in view like  
And..........
And  ((select count(*) from table A where conditions)=1 )then name is null
AND
in that code first we need to check first select query condition then we need to apply name is null condition. but i tried to run it but select query not run properly. because tables is used in View. 
The view below creates, however displays duplicate rows.  Why is this may I ask?
CREATE OR REPLACE VIEW customer_order_vw
AS
SELECT 
a.customer_id,
[Code]....
I have a table:
Name
_____
Smith Street
Smith Street
John Street
Ed Street
Ed Street
Ed Street
and need to assign sequence numbers only when the record (Name) changes, e.g. :
Name                 Seq
_____                ____
Smith Street       1
Smith Street       1
John Street        2
Ed Street           3
Ed Street           3
Ed Street           3
I have experimented with row_number partition but then i just get the sequence returning to 1 when the name value changes.
If I grouped the records by Name I would like to have unique, sequential numbers: 1, 2, 3 but where there is the same name I would like the sequence to stop and the number to replicate? 
I have one table in which I want to restrict some records from being inserted. I don't want to put any checked constraints. e.g. consider following table
transaction(
id number primary key,
txn_date timestamp(7),
payee varchar2(40),
amount number,
memo varchar2(40),
ref_num number
)
I want to write SQL which should not inset duplicate record.
e.g.
I have written one as bellow:
insert into transaction
select 1, to_date('2009-12-12','YYYY-MM-DD'), 'Payee1', 12, 'Test', 212 from dual where
(select count(*) from transaction where txn_date=to_date('2009-12-12','YYYY-MM-DD') and
payee='Payee1' and amount=12)=0;
Can I use exists/not exists, which query will be more appropriate. (Please consider that fields which I am using to filter out the duplicate transactions does not contain primary key.)
Can I write such SQL. Or do i check for duplicate rows one by one and then filter the duplicate records.
My requirement if id, join_date, join_time, result of table1 is matched with table2 at least one time then if repeating rows associated with the id should not come.Here is the test case.
create table table1
( id number , join_date varchar2(8), join_time varchar2(6), status varchar2(10));
create table table2
( id number , join_date varchar2(8), join_time varchar2(6), status varchar2(10));
insert into table1 values (01, '20010101', '0500', 'PASS');
insert into table1 values (01, '20010102', '0501', 'FAIL');
insert into table1 values (02, '20010103', '0502', 'PASS');
insert into table1 values (03, '20010104', '0503', 'FAIL');
insert into table1 values (04, '20010105', '0504', 'PASS');
insert into table1 values (05, '20010106', '0505', 'FAIL');
[code]...
I have tried the below mentioned query, whether any better query is there than this because in real-time data have 2 millions of record in table 1 and 60 thousand in table2. 
select distinct a.id, a.join_date, a.join_time, a.status
from table1 a,  table2 b
where a.id = b.id
and  (a.id, a.join_date, a.join_time, a.status) not in (select b.id, b.join_date, b.join_time, b.status
from table2 b)
and  a.id = (
select distinct  a.id
[code]....
I am using the below proc to delete some records
1)select client_id,count(*) from TCLIENT_NOTIFICATION_PACK where client_id=1620560178 group by client_id order by 2 desc; 
client_id     count(*)
-----------    ---------
16205601785128
2)select client_id, count(*)     from TCLIENT_NOTIFICATION_PACK
where client_id=1620560178
group by client_id
having count(*) > 40
order by 2 desc
client_id     count(*)
-----------    ---------
16205601785128
3)    select client_id,clnt_notification_pack_tid
-- bulk collect into  v_client_id,v_notif_tid
from (select clnt_notification_pack_tid,
client_id,
clnt_notification_pack_typ_tid,
crte_dt,
[code]....
4) Iam using the below proc to delete the rows from table, except the 4 rows returned above
declare
v_clnt_notification_pack_tid  TCLIENT_NOTIFICATION_PACK.CLNT_NOTIFICATION_PACK_TID%type;
 tYPE t_client_id is table of TCLIENT_NOTIFICATION_PACK.client_id%type;
tYPE t_notif_tid is table of TCLIENT_NOTIFICATION_PACK.clnt_notification_pack_tid%type;
v_client_id   t_client_id;
 v_notif_tid   t_notif_tid;
[code]....
5) After running this procedure, i shud see 5124 records, but i see zero records.
How to delete even rows of a table or rather alternate rows of a table.
View 31 Replies View Related