SQL & PL/SQL :: Insert Into Target Table And Delete From Source
			Jan 2, 2013
				We have a requirement to archive and purge the tables dynamically based on the control table input. For that we have to design a control table to gather the necessary information and passed to generate the queries.
I have designed the table as below.But in this case I am not able to handle the parent and child relation ship.
Suppose one table needs to be archived and purged and that table is parent table and it is having 2 child tables, so first required data will be inserted into target table and delete from source parent and child tables. so before deleting from parent we have to delete data from all 2 child tables.
Suppose one table needs to be purged and that table is parent table and it is having 5 child tables, so before deleting from parent we have to delete data from all 5 child tables.
To handle this scenario how can I design my control table.
For archive and purge the query like this.
INSERT INTO towner_name.ttable_name
(SELECT * FROM sowner_name.stable_name WHERE condition_column<=(sysdate-30));
DELETE FROM sowner_name.stable_name WHERE condition_column<=(sysdate-30);
for purge the quey is like this.
DELETE FROM sowner_name.stable_name WHERE condition_column<=(sysdate-30);
This is my control table and I have 300 tables list to archive and purge.
CID  SOWNER_NAME STABLE_NAME       TOWNER_NAME   TTABLE_NAME       CONDITION_COLUMN PERIOD UNIT TYPE
1     wedb_au    OFFER_HEADER       wedb_au      OFFER_HEADER       LAST_DATE        30     D    A
1     wedb_sa    OFFER_CUSTOMER     wedb_sa      OFFER_CUSTOMER     LAST_DATE        60     D    A
1     wedb_au    OFFER_SERVICE                                      LAST_DATE         1     Y    P 
1     wedb_us    OFFER_CUSTOMER                                     LAST_DATE        90     D    P
1     wedb_cn    OFFER_CARDS                                        UPDATE_DT        2      Y    P
2     wedb_au    ORDER_HEAD         wedb_au      ORDER_HEAD         LAST_DATE        120    D    A 
2     wedb_us    ORDER_CUSTOMER     wedb_us      ORDER_CUSTOMER     LAST_DATE        150    D    A
2     wedb_sa    ORDER_HEAD         wedb_sa      ORDER_HEAD         CREATION_DT      1      Y    A
3     wedb_us    DELIVERY_HEAD      wedb_us      DELIVERY_HEAD      UPDATE_DT        50     D    A
3     wedb_au    DELIVERY_CARDS     wedb_au      DELIVERY_CARDS     UPDATE_DT        200    D    A
3     wedb_au    DELIVERY_SERVICE   wedb_au      DELIVERY_SERVICE   LAST_DT          100    D    A
WHERE TYPE=P means insert and delete
TYPE=A means only delete
wedb_au.OFFER_HEADER is Parent Table.
child tables for wedb_au.OFFER_HEADER are wedb_au.OFFER_SERVICE,wedb_au.OFFER_BODY,wedb_au.OFFER_EMAIL,OFFER_TAX.
wedb_au.OFFER_SERVICE is child table and parent for this table is wedb_au.OFFER_HEADER
wedb_sa.OFFER_CUSTOMER  Stand alone table no relationship      
wedb_us.OFFER_CUSTOMER  Stand alone table no relationship
[code].......
	
	View 2 Replies
  
    
	ADVERTISEMENT
    	
    	
        Apr 6, 2011
        I currently try to transfer a partition of a table from a source to a target DB. For first test purposes I take both SYS users to avaoid privilege problems. I created below procedure from code fragments out of the net.The partition CSS_201001 from table CTRL_SETTLED_SHIPMENTS shall be transferred (I tried both with already existing partition and non existing on target destination), but I always get the following error at DBMS_DATAPUMP.OPEN:
Exception breakpoint occurred at line -1 of DBMS_SYS_ERROR.pls.
$Oracle.EXCEPTION_ORA_39001: 
ORA-39001: invalid argument value
ORA-06512: at "SYS.DBMS_SYS_ERROR", line 79
ORA-06512: at "SYS.DBMS_DATAPUMP", line 3043
ORA-06512: at "SYS.DBMS_DATAPUMP", line 4769
ORA-06512: at "SYS.TEST_DP", line 20
ORA-06512: at line 2
Listing:
create or replace
procedure test_dp is
-- Handle -- unique identifier for the datapump job
my_handle number;
  ind NUMBER;              -- Loop index
  percent_done NUMBER;     -- Percentage of job complete
[code].....
	View 7 Replies
    View Related
  
    
	
    	
    	
        Dec 14, 2012
        I am trying to insert records into target table from three source tables by using function in a package and I am getting error as follows.
SQL> create or replace
  2  PACKAGE
 casadm.sis_load_cpl_sis_reb_pgm_hist
  3  IS
  4     /**********************************************************************
******************
[code]....
ERROR at line 1:
ORA-06550: line 1, column 7:
PLS-00221: 'FN_LOAD1T_CPL_SIS_REB_PGM_HIST' is not a procedure or is undefined
ORA-06550: line 1, column 7:
PL/SQL: Statement ignored
	View 16 Replies
    View Related
  
    
	
    	
    	
        Nov 22, 2012
        I need to insert data in Table A from Table B where most of the fields are identical and might some of the fields will be more in Table A.
ex: Table A: a,b,c,d,e,f
      Table B: a.b,c,g,h
How to insert this using user_tab_columns in cursor and if I am giving the i/P as my table names . This needs to be configurable and reusable rather i mention all the fields in my logic.
	View 4 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
  
    
	
    	
    	
        Dec 18, 2012
        While i am trying to execute this proc,i am facing source does not have a runnable target issue.
 
CREATE OR REPLACE
PROCEDURE GET_CHILDS_SUB
( nid IN VARCHAR2
) AS
n varchar2;
CURSOR cur is SELECT node_id FROM test_tbl WHERE parent_id = nid;
BEGIN
[code]....
	View 14 Replies
    View Related
  
    
	
    	
    	
        Oct 3, 2011
        I have a table named SOURCE with about 1.000.000 rows looking like this
date         varchar2      varchar2    varchar2
DATE         ID1           ID2         AMOUNT
----------   -----------   ---------   --------
2010-07-03   1403          1403        1500
2010-07-13   2015438 etc   188608      6074
2010-08-28   1151927       410,4222    1750
2010-08-28   13622012      41026       178.99
2010-08-28   1600246       John        65
I want to insert the rows into a table TARGET
date         integer       integer     number
DATE         ID1           ID2         AMOUNT
There are about 10.000 rows where ID1, ID2 and/or AMOUNT contains characters. These rows I don't want to insert as the columns in the target table are INTEGER. I simply want to discard these.
	View 3 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
  
    
	
    	
    	
        Jul 21, 2010
        Source and Target db version : 10.2.0.4.0 
Source Os :Cent OS 5.4 and Target OS:Sun OS 5.10
We are loading data from source DB to target DB using dblink.Source db is having 15.4 crore records of number and varchar2 data types.
Using the logic as follows.
insert into table1 as select * from table1@dblinkname[/email];
DB link is working.If I give  "select * from scott.REPORT@DBLINK[/email]" in target db alone i could retrieve records.
Actual query:
Create Or replace procedure test_abcd as
begin
Insert into test select *
from scott.REPORT@DBLINK[/email]
dbms_output.put_line('Hello world');
end;   
When i give the above  query in sqlplus ,it is hanging. When i see the wait events i could find 
"Wait Event: SQL*Net more data from dblink" 
How to get the above things working.? when checked with network team they says there is no issue in the network. Do we need to modify any database/network level parameter  settings.there is no firewall between source and target db.
	View 9 Replies
    View Related
  
    
	
    	
    	
        Mar 9, 2011
        I have a staging table and a target table. How do I pull in last loaded data from staging table to target table?
	View 4 Replies
    View Related
  
    
	
    	
    	
        Jan 20, 2012
        I have a large 10G database, with records being inserted almost constantly.  In order to "UPDATE" records, I need to be able to DELETE the old record and INSERT the new record (even while records are being inserted into the table).  It appears that DELETES won't work while records are being inserted (1.5 million records per day).  Is there a way around this (which I'm assuming at this point is a contention issue)?  The INSERT uses the NOPARALLEL hint; no hints on the DELETE.
	View 7 Replies
    View Related
  
    
	
    	
    	
        Jun 22, 2012
         I have a website I am working on a database for, and to insert new data into the table is not a problem, even to output the table isn't an issue.
But a delete query won't work and it doesn't return any errors or echo commands that I put in the steps of the logic.
	View 11 Replies
    View Related
  
    
	
    	
    	
        Feb 6, 2009
        I am trying to write a trigger that will do an insert/delete/update into a audit table when a change has occurred on the primary table. The change will be recorded in the audit table by a incemental sequence number and the updated data.
there will be an extra column in the audit table
how to get a simplified version of this trigger.
the primary table will look like so
Id_num varchar (20)
code Integer
desc varchar(20)
sequence_num Integer
audit table
Id_num varchar(20)
code Integer
desc varchar(20)
timestamp date
sequence_num Integer
	View 6 Replies
    View Related
  
    
	
    	
    	
        Dec 17, 2012
        I have 4 tables , Certain users need to (Select ,insert,delete) certain rows only based on nApplication id
All the tables have Application Id , Based on this application id user will (Select ,insert,delete)
I tried row level security DBMS_RLS.add_policy but it hangs every time when i query the data or when i try to drop the policy. Is there is any method to resolve this issue.
If only Row level security will solve this issue , give me some example
	View 18 Replies
    View Related
  
    
	
    	
    	
        Sep 28, 2011
        Below is my requirement, 
Source Table: SRC
COL1 DATE_CREATED CREATED_BY
1     27-SEP-2011    GURU
1     28-SEP-2011    SANKAR
Target Table:TGT
COl1 DATE_CREATED CREATED_BY
1     28-SEP-2011  SANKAR
I need to take the MAX of date_created record and store it in target.
I tried, 
select max(date_created), col1, created_by from src
group by col1, created_by,date_created
Which is giving me 2 records which i don't want. How to get only one record out of that source table?
	View 2 Replies
    View Related
  
    
	
    	
    	
        Sep 4, 2013
        i have a existing table called table_1 to did some changes to it, but i need to do a source search to find where all  in the code that we reference this code to ensure that there is not a variable declaration that sets this to a specific number. how do i do a source search. i alter a existing column (overbook_max) to number(2) tonumber (3)
	View 8 Replies
    View Related
  
    
	
    	
    	
        Dec 17, 2010
        How to get all the name of tables that a user can select, insert, update or delete?
	View 2 Replies
    View Related
  
    
	
    	
    	
        Jun 21, 2013
        create table src(id number,val number,data varchar2(100)) insert into src values (1,1,'SUN');
insert into src values (2,2,'WED');
insert into src values (3,3,'MON');     
create table trg(id number,val number,data varchar2(100)) required rows to be inserted in the target table. 
  insert into trg values (1,1,'SUNDAY');
insert into trg values (2,0,NULL);
insert into trg values (2,0,NULL);
insert into trg values (3,0,NULL);
insert into trg values (3,0,NULL);insert into trg values (3,0,NULL); 
 {code} based on the column value  of the source table src's column val , i need to populate my target table trg . If the value of val is 1 then  only one target row is created in the target .If the value of val in the source table src is 2 then the target is populated with 2 rows .The values of the target columns are mapped as follow:
1)id -as it is
2)val - if the val of src is 1 then map the val as it is .If the value of val is more than one then create as many rows as the value of val ,id will be as it is and the  value of val and data will be null
3)data - if the val of src is 1 then expand the abbreviation else null . 
	View 17 Replies
    View Related
  
    
	
    	
    	
        Jul 26, 2012
        For triggers, is it possible to do separate actions on insert , update and delete. For example, if insert is the case, do select; if update is the case, do select from another table and so on?
	View 1 Replies
    View Related
  
    
	
    	
    	
        Aug 10, 2005
        I have multirecord block and I want to disable Inserting/Updating/Deleting more then one record at a time.
	View 32 Replies
    View Related
  
    
	
    	
    	
        Sep 24, 2010
        I got html source code inserted into the table as CLOB (or BLOB). And I would like to search a some word from that.When I find a some value I can write this one into the column.It would be easy if this code is xml but isnt. 
	View 12 Replies
    View Related
  
    
	
    	
    	
        Apr 29, 2013
        i have 2 tables in two different sources.
I have loaded data from source to destination.
some rows are missed while loading.
i want to know the missing rows
	View 11 Replies
    View Related
  
    
	
    	
    	
        Jan 11, 2011
        I want to replicate single table data/modification from source db to destination DB.procedure or steps how to create replication between source and dest db for single table.
	View 18 Replies
    View Related
  
    
	
    	
    	
        Aug 30, 2012
        i have one table ot_ins_item where user will enter the details of item, grade,item qty , later on user will go and update the same table the details of different grades received for the same item in different columns with qty breakup in 3 different fields it_qty_01 , it_qty_02,it_qty_03 respectively with different grades , what i need is i want is whenever he updates this table with different grades based on data entered in 3 different fields , a procedure or trigger should delete the initial record saved and insert three different rows based on newly updated values , it may be 3 or it may be 2 sometime depending upon input values that many records should be inserted same time controlling the qty's entered in breakup not exceeding the main qty.
CREATE TABLE ot_ins_item (it_ins_no NUMBER,it_no NUMBER,it_grade VARCHAR2(12),
it_code VARCHAR2(12),it_qty NUMBER,it_flex_01 VARCHAR2(12),
it_01_qty NUMBER,it_flex_02 VARCHAR2(12),it_02_qty NUMBER,it_flex_03 VARCHAR2(12),
it_03_qty NUMBER);
create sequence s_it_no start with 1 ;
INSERT INTO OT_INS_ITEM VALUES (1,s_it_no.NEXTVAL,'A','ITEM1',NULL,NULL,NULL,NULL,NULL,NULL);
INSERT INTO OT_INS_ITEM VALUES (1,s_it_no.NEXTVAL,'B','1TEM2',NULL,NULL,NULL,NULL,NULL,NULL);
INSERT INTO OT_INS_ITEM VALUES (1,s_it_no.nextval,'C','ITEM3',NULL,NULL,NULL,NULL,NULL,NULL);
SELECT * FROM OT_INS_ITEM;
[code]....
	View 5 Replies
    View Related
  
    
	
    	
    	
        Sep 7, 2013
        I have requirement as follows.  I need to load the data to the target table on every Saturday. My source file consists of data of several sates. For every week i have to load one particular state data to target table.  If first week I loaded AP data, then second week on Saturday karnatak, etc. 
Provide code also how can i schedule the data load with every Saturday  with different state column values automatically.
	View 2 Replies
    View Related
  
    
	
    	
    	
        Jan 15, 2011
        I have a confusion with MEMORY_TARGET and MEMORY_MAX_TARGET parameter. if i set SGA_TARGET, SGA_MAX_SIZE along with MEMORY_TARGET and MEMORY_MAX_TARGET then how oracle will manage the memory? Because as per my understanding if we set MEM
	View 3 Replies
    View Related
  
    
	
    	
    	
        Aug 24, 2012
        We are using the 11.1.0.7 database, we implemented the Memory_Max_Target and Memory_target in the database.Here is the value of the memory parameters:
SQL> show parameter memory_
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
hi_shared_memory_address integer 0
memory_max_target big integer 3G
memory_target big integer 2G
shared_memory_address integer 0
We want to increase the value of the Memory_target=3G, means, I want to increase the value of the memory_target upto Memory_max_target by using below command:alter system set MEMORY_TARGET=3G scope=both SID='OLTP1'; but I am getting below error:
ERROR at line 1:
ORA-02097: parameter cannot be modified because specified value is invalid
ORA-00846: could not shrink MEMORY_TARGET to specified value
I tried to give the memory_target value less than the memory_max_target value like:alter system set MEMORY_TARGET=2900M scope=both SID='OLTP1'; but get the same error:
ERROR at line 1:
ORA-02097: parameter cannot be modified because specified value is invalid
ORA-00846: could not shrink MEMORY_TARGET to specified value
	View 6 Replies
    View Related
  
    
	
    	
    	
        Oct 19, 2011
        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.
	View 23 Replies
    View Related
  
    
	
    	
    	
        Jul 7, 2011
        I want to delete the duplicate rows in a table. there is no column which can be used to differentiate between the rows. 
SELECT   column_name1
FROM [table]
WHERE column_name2 = cond
GROUP BY column_name1
HAVING COUNT (column_name1) > 1
from the above query i can find the duplication in the table and can delete through it. But what i want one record of each duplication not to be deleted most probably the record added last to the table.
	View 13 Replies
    View Related
  
    
	
    	
    	
        Jan 18, 2013
        delete table if exist
How do we write this code in oracle / sqlplus
	View 4 Replies
    View Related