PL/SQL :: Update Duplicate Records In Table With Sequence Value
			Mar 25, 2013
				My table have duplicate records. I want to impose a primary key on that table. For that I have to replace duplicate values of a column with next value of a sequence. 
	
	View 2 Replies
  
    
	ADVERTISEMENT
    	
    	
        Sep 20, 2011
        The requirement is I have a table (TAB1), wherein I have 3 columns, ID, LID and STATUS. 
The value in ID column = ID_SEQ.NEXTVAL,and LID will be either 0 or 1 and the possible values for STATUS are 'ED','CP', NULL. The ID column is not suppose to have duplicate values, but there is no check on the table for the same.
Someone has updated the existing data and ID column is containing duplicate values. Wherever LID = 0 and STATUS = NULL and if only if ID is duplicated then the ID_SEQ.NEXTVAL has to be assigned to ID field, so that there are no more duplicate values.
CREATE TABLE tab1 (id NUMBER , lid NUMBER, status VARCHAR2(10));
Existing Data
------------------
INSERT INTO tab1 VALUES (1,0, 'ED');
INSERT INTO tab1 VALUES (1,0, 'CP');
INSERT INTO tab1 VALUES (1,0, NULL);
INSERT INTO tab1 VALUES (1,0, NULL);
INSERT INTO tab1 VALUES (1,0, NULL);
INSERT INTO tab1 VALUES (1,0, NULL);
[code]....
get the result using a single update statement.
	View 5 Replies
    View Related
  
    
	
    	
    	
        Jun 1, 2010
        I am trying to update records in the target table based on the records coming in from source. For instance, if the incoming record is present in the target table I would update them in the target else I would simply insert. I have over one million records in my source while my target has 46 million records. The target table is partitioned based on calendar key. I implement this whole logic using Informatica. Looking at the informatica session log I find that the informatica code is perfectly fine but its in the update part it takes long time (more than 5 days to update one million records). find the TARGET TABLE query and the UPDATE query as below.
TARGET TABLE: 
CREATE TABLE OPERATIONS.DENIAL_REGRET_FACT
(
  CALENDAR_KEY                  INTEGER         NOT NULL,
  DAY_TIME_KEY                  INTEGER         NOT NULL,
  SITE_KEY                      NUMBER          NOT NULL,
  RESERVATION_AGENT_KEY         INTEGER         NOT NULL,
  LOSS_CODE                     VARCHAR2(30)    NOT NULL,
  PROP_ID                       VARCHAR2(5)     NOT NULL,
 [code].....
	View 9 Replies
    View Related
  
    
	
    	
    	
        Apr 13, 2011
        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.
	View 10 Replies
    View Related
  
    
	
    	
    	
        Aug 30, 2010
        How can i delete duplicate records from the table.
	View 2 Replies
    View Related
  
    
	
    	
    	
        Jun 15, 2012
        query to count the duplicate records and to display duplicate records in a table. Iam using oracle 10g.
	View 2 Replies
    View Related
  
    
	
    	
    	
        Sep 29, 2011
        How can I delete the duplicate combination of records from the below table.
CREATE TABLE test
(
gidNUMBER(10),
pidNUMBER(10)
);
INSERT INTO test VALUES (10,20);
INSERT INTO test VALUES (20,10);
INSERT INTO test VALUES (25,46);
[code]....
The condition is if GID = PID and PID = GID then only one combination of these records should be retained. For example Out of 10-20 and 20-10 only one record should be retained.
Expected result after deletion
       GID        PID
---------- ----------
        10         20
        25         46
        89         64
        15         16
        19         26
	View 5 Replies
    View Related
  
    
	
    	
    	
        Dec 8, 2012
        I had created a new table named USERLOG with two fields from a previous VIEW. The table already consist of about 9000 records. The two fields taken from the VIEW, i.e. weblog_views consist of IP (consists of IP address), and WEB_LINK (consists of URL). This is the code I used,
CREATE TABLE USERLOG
AS
SELECT C_IP, WEB_LINK FROM weblog_views;
I want to add another column to this table called the USER_ID, which would consists of a sequence starting with 1 to 9000 records to create a unique id for each existing rows. I'm using Oracle SQL Developer: ODMiner version 3.0.04. I tried using the AUTO-INCREMENT option,
ALTER TABLE USERLOG
ADD USER_ID INT UNSIGNED NOT NULL AUTO_INCREMENT;
But I get an error with this,
Error report:
SQL Error: ORA-01735: invalid ALTER TABLE option
01735. 00000 -  "invalid ALTER TABLE option"
	View 2 Replies
    View Related
  
    
	
    	
    	
        Dec 8, 2012
        I had created a new table named USERLOG with two fields from a previous VIEW. The table already consist of about 9000 records. The two fields taken from the VIEW, i.e. weblog_views consist of IP (consists of IP address), and WEB_LINK (consists of URL). This is the code I used,
CREATE TABLE USERLOG
AS
SELECT C_IP, WEB_LINK FROM weblog_views;
I want to add another column to this table called the USER_ID, which would consists of a sequence starting with 1 to 9000 records to create a unique id for each existing rows. I'm using Oracle SQL Developer: ODMiner version 3.0.04. 
I tried using the AUTO-INCREMENT option,
ALTER TABLE USERLOG
ADD USER_ID INT UNSIGNED NOT NULL AUTO_INCREMENT;
But I get an error with this,
Error report:
SQL Error: ORA-01735: invalid ALTER TABLE option 01735. 00000 -  "invalid ALTER TABLE option"
	View 4 Replies
    View Related
  
    
	
    	
    	
        Feb 6, 2013
        I use a sequence to generate an alphanumeric code and I need to update all rows of a table with that sequence. The sequence is created with this code:
SELECT (CHR(TRUNC(s.nextval/1000) + ASCII('A')) || LTRIM(TO_CHAR(MOD(s.currval,1000),'099'))
FROM dual;
I have tried many things - most recently
Update t3_temp_table
SET mergecode = 
SELECT (CHR(TRUNC(s.nextval/1000) + ASCII('A')) || LTRIM(TO_CHAR(MOD(s.currval,1000),'099'))
FROM dual;
I get missing expression error.
It works fine if I use a straight s.nextval
	View 5 Replies
    View Related
  
    
	
    	
    	
        Mar 6, 2013
        create table test1
  ( ID                               NUMBER(11)
 ,MEMBER_NMBR       NUMBER(10)
 ,CODE_NMBR            NUMBER(7)
 ,ROW_EFCTV_DT        DATE
 ,ROW_TRMNTN_DT       DATE
[code]....
 insert into test1 values (11007,7462,32,'30/sep/2012','31/dec/9999',3,'25/sep/1998','AUTUMN',1,0,344);
 insert into test1 values (11007,7462,32,'30/oct/2012','31/dec/9999',3,'25/sep/1998','AUTUMN',1,0,344);
IDMEMBER_NMBRCODE_NMBRROW_EFCTV_DTROW_TRMNTN_DTFLAG_NMBRBRTH_DTNAMECLAIM_CDAMT1AMT2
1100774623209/30/2012 00:0012/31/9999 00:00309/25/1998 00:00AUTUMN10344
1100774623210/30/2012 00:0012/31/9999 00:00309/25/1998 00:00AUTUMN10344
I have to update the row_trmntn_dt of first row to row_efctv_dt of 2nd row which is 30th Oct 2012 - 1 day i.e. 29th Oct 2012
	View 10 Replies
    View Related
  
    
	
    	
    	
        Feb 2, 2012
        I'm working with Oracle 10g.
I have a table like this;
ID        Amount   Date
123        5000     Oct-07-2011
123         null      Oct-09-2011
124        7000     Oct-14-2011
124         null      Oct-17-2011
124         null      Oct-24-2011
What I'm trying to do here is loop thruogh the records and update the amount that's null with the previous amount with  the same ID.
	View 3 Replies
    View Related
  
    
	
    	
    	
        Nov 4, 2009
        CREATE TABLE "SCOTT"."SEATALLOTMENT" 
   ("YEAR" NUMBER(4,0), 
"COLLEGECODE" CHAR(4 BYTE), 
"COURSECODE" CHAR(3 BYTE), 
[Code].....
Now i want to UPDATE  reducing  the AVAILABLE  column by 1  in COURSESEATS table based on common columns  collegecode,coursecode for a ROW  inserted into SEATALLOTMENT table ,i am confused to what approach i have to follow whether its a procedure or a trigger 
CASE:
Here in this case as i insert a row with krcl,cse as college code and course code respectively into seatallotment table the available column  in courseseat table for the respective row with mentioned common column must become 59 from 60
	View 5 Replies
    View Related
  
    
	
    	
    	
        Jul 29, 2013
        I need to update more than 1million records in a table. I am using Oracle Warehouse Builder to do this Job. it is taking more than 3 hours still running. I don't have any Indexes on this table.
	View 11 Replies
    View Related
  
    
	
    	
    	
        May 26, 2011
        i have a table in my PD database which have more than 30,000 records .some records in a column say p_code is not tagged with code like '9876543'while other records are tagged in this column with code such as '19022345678'.
Now i want to update these records with tagging 1902 with each one .   
	View 26 Replies
    View Related
  
    
	
    	
    	
        Sep 21, 2012
        Lets take the basic emp table for our Referenece and lets assume that it contains around 60000 Records and all the deptno in that table are Initially 10. Please provide an update statement which would update deptno column of EMP table((based on) order by EMPNO) in for every 120 records incrementing by 1.(DeptNo to be incremented by 1,like 10 ,11 , 12 etc).
First 120 Records deptno should be 10,
Next 120 Records deptno should be 11, and so on.
.
.
.
.
.
.
For Last 120 records deptno should be updated with 500.
	View 3 Replies
    View Related
  
    
	
    	
    	
        Nov 20, 2009
        want to update 230 records in ins_spr table but its returning error..
Sql statement in blue color returning 230 records.
------------------------------------------------
update ins_spr set
SPR_EXCC = 'NORSk'
where spr_code = (select distinct spr_code from ins_spr where spr_levc = 'N' and spr_facc = 'ROS' and (sts_code = 'AP' or sts_code = 'LS') and spr_stuc in (select distinct a.sqe_stuc from srs_sqe a where a.SQE_EQEC = 'NP3M' and a.SQE_SQSC = 'BE' and a.sqe_stuc in ( select  distinct b.sqe_stuc from srs_sqe b where a.sqe_stuc=b.sqe_stuc and SQE_EQEC = 'NP3S' and SQE_SQSC = 'BE')))
OR
update ins_spr set
SPR_EXCC = 'NORSK'
where spr_code = (select spr_code from ins_spr where spr_levc = 'N' and spr_facc = 'ROS' and (sts_code = 'AP' or sts_code = 'LS') 
and exists (select sqe_stuc from srs_sqe a where sqe_stuc = substr(spr_code,1,8)  and SQE_EQEC = 'NP3M' and SQE_SQSC = 'BE' 
and exists ( select sqe_stuc from srs_sqe b where a.sqe_stuc=b.sqe_stuc and SQE_EQEC = 'NP3S' and SQE_SQSC = 'BE')))
	View 1 Replies
    View Related
  
    
	
    	
    	
        Dec 21, 2012
        I am trying to insert rec into target table if those rec are not existing and trying to update those rec if they already exists from three source tables.I had seen in posts that merge cannot be used with cursor.
SQL> create or replace
2  PACKAGE                                sis_l_cpl_sis_reb_pgm_hist_pkg
3  IS
4     /********************************************************************
******************
5        PACKAGE:    sis_load_cpl_sis_reb_pgm_hist
6        PURPOSE:    Load CMPLY_SIS_REB_PGM_HIST with data from cmply_sis_p
h_dtl,cmply_sis_sls_dtl,
7                    cmply_sis_excl_dtl(intial load)
8     *********************************************************************
******************/
[code]....... 
     
Package created.
SQL> create or replace
2  PACKAGE BODY
sis_l_cpl_sis_reb_pgm_hist_pkg
3  IS
4     /**********************************************************************
******************
5        PACKAGE:    sis_l_cpl_sis_reb_pgm_hist_pkg
6        PURPOSE:    Load CMPLY_SIS_REB_PGM_HIST with data from cmply_sis_pur
h_dtl,cmply_sis_sls_dtl,
7                    cmply_sis_excl_dtl(intial load)
[code].......  
Warning: Package Body created with compilation errors.
SQL> sho err
Errors for PACKAGE BODY SIS_L_CPL_SIS_REB_PGM_HIST_PKG:
LINE/COL ERROR
-------- -----------------------------------------------------------------
67/7     PL/SQL: SQL Statement ignored
75/19    PL/SQL: ORA-00926: missing VALUES keyword
	View 10 Replies
    View Related
  
    
	
    	
    	
        Sep 16, 2013
        what are the type of ways to update the 10 million records table with certain condition?
	View 2 Replies
    View Related
  
    
	
    	
    	
        Jul 5, 2010
        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? 
	View 9 Replies
    View Related
  
    
	
    	
    	
        Nov 18, 2011
        I have a table with three columns mentioned below :
Col1   Col2    Col3
121
221
331
431
531
622
722
Col1 is the primary key.I need a sql query which will show the data set mentioned below :
Col1   Col2    Col3  Seq
121     1
221     1
331     2
431     2
531     2
622     3
722     3
I need all the 7 records to be displayed.
	View 16 Replies
    View Related
  
    
	
    	
    	
        Apr 16, 2010
        I am having a table with 4 columns as mentioned below
For a particular prod the value greater less than 5 should be rounded to 5 and value greater than 5 should be rounded to 10. And the rounded quantity should be adjusted with in a product starting with order by of rank with in a prod else leave it
Table1
Col1prodvalue1rank
1A21
2A62
3A53
4B61
5B32
6B73
7C41
8C22
9C13
10C74
Output
Col1prodvalue1rank
1A51
2A52
3A33
4B101
5B02
6B63
7C51
8C52
9C03
10C44
I have taken all the records in to a cursor. Once after rounding the request of 1st rank and adjusting the values of next rank is done. Trying to round the value for 2nd rank as done for 1st rank. Its not taking the recently updated value(i,e adjusted value in rounding of 1st rank).
This is because of using a cursor having a value which is of old value. Is there any way to handle such scenario's where cursor records gets dynamically updated when a table record is updated.
	View 9 Replies
    View Related
  
    
	
    	
    	
        Dec 22, 2010
        i am using this query to see only duplicate records but not able to get through
select * from
 emp
 where rowid NOT IN
 ( select max(rowid) from emp GROUP BY job_id)
	View 7 Replies
    View Related
  
    
	
    	
    	
        May 20, 2010
        i have table with name, count, flag with dublicate records
example 
with swayam name , counts are 3, 4
with ramana name, counts are 5,5
with reddy name, counts are 1,2,3
i want to update the flag
if count are same then update one of record (flag='A') and other should be flag='R'
if count are different then update the max count (flag='A') and other should be reject remaing (flag='R'). use below quires 
CREATE TABLE TEST_DUB ( NAME VARCHAR2(99), V_COUNT NUMBER, FLAG VARCHAR2(1));
Insert into TEST_DUB (NAME, V_COUNT)
Values
('SWAYAM', 3);
Insert into TEST_DUB
(NAME, V_COUNT)
Values
[Code]....
	View 4 Replies
    View Related
  
    
	
    	
    	
        Jun 22, 2010
        My duplicate records have been detected by First Name, Last Name, Name, and City.
such as 
select  FirstName, LastName, Name, City, count(*) as Num of Duplicate from TABLE 
GROUP BY FirstName, LastName, Name, City
having count (*) > 1
It gives the duplicate record. Now I need all the columns and the each duplicate record in the select, so I can see why these records are duplicate.
	View 6 Replies
    View Related
  
    
	
    	
    	
        Dec 20, 2012
        I have a table and it's having duplicate records.
for one particular employee, he is having multiple records with the same data in the table
EMPNO    ENAME     JOB     SAL     DOB
-------------------------------------------------------
1               A           X        100     1956
2               B           Y        200     1974
1               A           X        100     1956
3               C           Z        300     1920
[Code]....
like this am having multiple times the duplicates.
I have written the below query to delete the duplicate records. But it is deleting only one record (if we have 5 duplicates it is deleting only 1 ). But I am looking to delete if we have 5 duplicates need to delete 4 duplicates and keep 1 record in the table. 
query which am using to delete the duplicates is 
DELETE FROM Table1 a  
WHERE ROWID IN (SELECT MAX(ROWID)  
                FROM Table2 b 
                WHERE a.ID = b.ID);  
it is deleting only one row but I want to delete 4 records out of 5 and keep one record. 
	View 12 Replies
    View Related
  
    
	
    	
    	
        Sep 29, 2010
        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... 
	View 5 Replies
    View Related
  
    
	
    	
    	
        Oct 25, 2011
        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
	View 5 Replies
    View Related
  
    
	
    	
    	
        Feb 23, 2010
        create table x (
field1 varchar2(10) );
insert into x values ('001-002');
insert into x value ('0150-0152');
insert into x value ('0100-0101');
create table y (
field varchar2(6));
recortd in table y 
001
002
0150
0151
0152
0100
0101
	View 15 Replies
    View Related
  
    
	
    	
    	
        Sep 30, 2013
        , im having this trouble to update some records, the problem is i have  I have this table with some transactions and each row have a cd_cli (client code), dt_ven (date of the transaction) and a product id (cd_prod) the trouble is, i insert a row for each product in this table, then i have like this
  110001YURI AGUIRREWALLMA400V44-B469,0019/9/2013210001YURI AGUIRRESU-7N-B78,0019/9/2013310001YURI AGUIRREWALLSF35V22-S78,5719/9/2013410003WILLIANWALLSA470V22-BS449,002/9/2013 but i need to update the CD_TRANS for each row with the same number like all the YURI AGUIRRE recode must have like CD_TRANS 1, and the WILLIANs CD_TRANS must be 2 and the next must be cd_trans 3, but I've tried to update the table for a lot of ways but i don't have success trying to do this, the last thing i had tried was  
MERGE INTO TVEN_TEMP a
     USING (SELECT CD_CLI, DENSE_RANK () OVER (ORDER BY DT_VEN) new_seq_num
              FROM TVEN_TEMP
             WHERE CD_TRANS IS NULL) b
        ON (a.CD_CLI = b.CD_CLI)
[code]....
	View 8 Replies
    View Related