SQL & PL/SQL :: Splitting Large Table Output
			Sep 20, 2012
				I need to dump the contents of a very large table into text files for archiving as we retire this old DB.  The table has about 16 million rows, and a few of the columns are up to 4000 characters wide (varchar2(40000)).  I've got 2 problems:
1) How can I select records that occur in a certain month of a year (there is a date column) and put the selected records into a file?
2) I don't have access to the server OS, so UTL_FILE is not possible.  The output is also so large that I'm having trouble with the DBMS_OUTPUT.PUT_LINE.  
 I'm trying to get the first block of the IF working first, so the rest is just placeholders.  
DECLARE
  v_mm number (2);
  v_yyyy number (4);
  min_mm number (2);
  min_yyyy number (4);
  max_mm number (2);
  max_yyyy number (4);
  min_date date;
[code]....  
	
	View 12 Replies
  
    
		
ADVERTISEMENT
    	
    	
        Jan 25, 2013
        i have three tables and all of these tables have around 30L records.
Using join i am retrieving records from these tables but it is taking much more time to get output.
Partition can improve performance?
	View 7 Replies
    View Related
  
    
	
    	
    	
        Sep 25, 2013
        Currently I have a requirement where I need to create 2 more output rows using each result row.
In my requirement I am populating charges table with types of charges, on each line item of charges, I need to apply 2 types of taxes and populate it along with the charge line item. I will be storing charges in table charges and the 2 taxes to be applied in taxes table respectively. For each row of charges, i need to apply these 2 taxes present in taxes table resulting in 3 rows output.
--Create tables charges 
create table charges
(
charge_type varchar2(10) ,
charge number
);
[Code]....
My expected output should be like below:
 
Item_type            amount          
-------------------- ---------- 
charge1               100       
Charge1_tax1          10        
Charge1_tax2          20        
charge2               200       
Charge2_tax1          20        
Charge2_tax2          40        
how I can achieve the expected output using a single sql query
	View 6 Replies
    View Related
  
    
	
    	
    	
        Aug 15, 2012
        I am searching for a decent method / example code to subdivide a large table (into a global temp table (GTT) for further processing) based on a list of numeric/alphanumeric which is the resultset from a view.
I am groping with the following strategy in PL/SQL:
1 -- set up cursor, execute the view (so I have the list of identifiers)
2 -- create a second cursor (or loop?) which: accepts each of the identifiers in turn executes a query (EXECUTE IMMEDIATE?) on the larger table INSERTs (or appends?) each resultset into the GTT
3 -- Then the GTT contains just the requires subset of the larger table for further processing and eventual import into iReport for reporting.
GTT is defined and ready to go, the larger table contains approx 40,000 rows and I need to extract a dozen subsets or so which add up to approx 1000 rows.
	View 10 Replies
    View Related
  
    
	
    	
    	
        May 8, 2010
        Table Name : Trans
chitta_enn        number(10,0)
varavu_patti      varchar2(100)
pattru_patti      varchar2(100)
Thogai            number(10,2)
where in the data's are as follows
chitta_enn    varavu_patti  pattru_patti     Thogai
101           panam         null             101.00
101           null          sambalam         51.00
101           null          kamishan         50.00
I need to create the view as follows
View Name : Pattiyal
vivaram       varchar2(2000)
varavu        number(10,2)
pattru        number(10,2)
The view data should get display as follows
vivaram               varavu        pattru        
sambalam kamishan      null         101.00      
panam kamishan         51.00         null
panam sambalam         50.00         null
Logic:
Each table row will have only one value either in varavu_patti or in pattru_patti. On selecting the row, thogai must be posted in varavu when varavu_patti is not null or should be posted in pattru when pattru_patti is not posted.on selecting the table row, vivaram should contain all other rows varavu_patti and pattru_patti on equating chitta_enn
 
Is it possible to create a view as above
	View 1 Replies
    View Related
  
    
	
    	
    	
        May 14, 2013
        11.2.0.3...just trying to learn the syntax. I have not worked with IOTs and I am exploring a feature I have not really used to try to learn something new. I know about intervals.This exact split syntax below, works on a heap table without errors. When I run the following split against a regular heap table it works. 
CREATE TABLE MYTABLE (
INSERT_DATE date,
myfield1 varchar2(50),
myfield2 varchar2(50),
myfield3 varchar2(50),
[code]....
alter table MYTABLE split partition "FUTURE" at ( to_date('09_MAY_2013_13','DD_MON_YYYY_HH24' ) ) into ( partition "B4_09_MAY_2013_13", partition "FUTURE" ) update global indexes
               *
ERROR at line 1: ORA-00932: inconsistent datatypes: expected BINARY got NUMBER
	View 4 Replies
    View Related
  
    
	
    	
    	
        Apr 8, 2013
        splitting a table partition without making its primary key index ar any other indexes unusable.
I think it is possible to do so 10g onwards.
DB Details:
Oracle RDBMS 11.2.0.3, HP-Ux B.11.31, OLTP
	View 2 Replies
    View Related
  
    
	
    	
    	
        Aug 12, 2013
        I want to add column to table which has huge amount of data and fill with data from another table. What is the best way to do it? Is it faster to use CTAS instead of ALTER TABLE ADD COLUMN?
	View 2 Replies
    View Related
  
    
	
    	
    	
        May 13, 2011
        How to estimate next extent size for very large table? What should I take into account? Is there any formula for that?
	View 4 Replies
    View Related
  
    
	
    	
    	
        Sep 2, 2011
        I have two large tables(rptbody and rpthead) which has over millions or even more records. Below is the table schema
describe rpthead
Name                        Null     Type          
--------------------------- -------- ------------- 
RPTNO                       NOT NULL NUMBER        
RPTDATE                     NOT NULL DATE          
RPTD_BY                     NOT NULL VARCHAR2(25)  
PRODUCT_ID                  NOT NULL NUMBER 
[code]...
What I want is getting all data if the referenced RPTNO belongs to a particular product_id from rptbody table, here's the sql
SELECT t0.LINENO, t0.COMMENTS, t0.RPTNO, t0.UPD_DATE
     FROM RPTBODY t0  
     WHERE 
    (
        t0.RPTNO IN  
       ( 
         SELECT  t1.RPTNO FROM RPTHEAD t1 where t1.PRODUCT_ID IN ('4647') 
       )
    )
    ORDER BY t0.LINENO
Since the result set is pretty large, so my application(think it as c couple of jobs, each job should be finished in a time window) can only process a subset of all data, so I need pagination so that the next job can continue the processing until all data is processed, below is the SQL with pagination
select * from ( 
  select  a.*, ROWNUM rnum  from 
  ( 
    SELECT t0.LINENO, t0.COMMENTS, t0.RPTNO, t0.UPD_DATE
     FROM RPTBODY t0  
     WHERE 
    (
[code]....      
As you can see each query will take 100 rows from the db. The problem for now is that the query taking too much of time(10+ mins), I know the slowness is due to "ORDER BY t0.LINENO", but it's required for pagination. 
	View 4 Replies
    View Related
  
    
	
    	
    	
        Sep 30, 2012
        I am trying to create a new index on large table of size around 100GB. but i am getting the following error:
ORA-1652: unable to extend temp segment by 128 in tablespace TEMP.
temp tablespace size is : 20 GB.
does it mean that the whole index will be created at temp tablspace first?
	View 3 Replies
    View Related
  
    
	
    	
    	
        Apr 30, 2013
        Consider tables A,B,C,D,E,F. all are having 100000++ records Tables B,C,D are dependent on table A (with foreign key constraint). When I am deleting records from all tables, table B,C,D are taking max 30-40 seconds while table A is taking 30-40 mins. All tables are having indexes.
Method I have used:
1. Created Temp table 
2. then deleted all records from B,C,D,E,F for all records in temp table for limit of 500. 
delete from B where exists (select 1 from temp where b.col1=temp.col1);
3. Why it is taking too much time for deleting records in table A.
Is there any thing that during deleting data from such master table, it is referring to all dependent tables even if dependent data is not present ?
	View 12 Replies
    View Related
  
    
	
    	
    	
        Aug 26, 2011
        I am working with an online application with the database in Oracle 10G. We have a table with 10 million rows and this table is subjected to grow in future also. Moreover we cannot archive some of these rows as these records are required for referencing.
We have all necessary indexes on the table but querying this table takes a lot of time especially when it is joined with other tables. some methods with which I can manage this table in a better way so that queries joining this table would execute faster..
SELECT 
  TAB1.C6, 
  TAB1.C8,
  TAB1.C10, 
  TAB3.C4,
[code]....
	View 7 Replies
    View Related
  
    
	
    	
    	
        Apr 9, 2010
        We have two databases running on 10.2.0.4 and 9.2.0.8. Both are having the same unpartitioned table of size 80G. I am exporting the table on 10g by using parallel=8 and dumpfile with %U option. That took around 4 hours to export the table.
And on 9.2.0.8, i am exporting using below parameters, taking around 5 hours.
buffer=2000000
recordlength=64000
options i can try to speed up the export in both versions.
	View 2 Replies
    View Related
  
    
	
    	
    	
        Sep 2, 2011
        I have a large table and want to calculate just a few values. Therefore, I don't want to create a new table, I want to update the table. Here an example:
I want to calculate the VALUE_LAG with ID = 4 only (-> two values).
create table zTEST
( PRODUCT  number,
  ID       number,
  VALUE    number,
  VALUE_L1 number );
[Code]..
I tried this, but obviously, windows functions are not allowed in the update statement.
update zTEST
set VALUE_L1 = lag(VALUE) over (partition by PRODUCT, order by ID)
where ID = 4
How can I do this?
	View 12 Replies
    View Related
  
    
	
    	
    	
        Apr 26, 2010
        I have a query on , how to view the sample data from a very table which is large in size ( more than 10 million ).
I just need to see some sample data from a large table ( to see what kind of data which is application related ).
My question is :
Select *
from Sample_table
where rownum < 10
is this a Good way to view the sample data ?
I have understanidng that the rownum will be assigined to the rows once all the rows are reteived.
So what is the best way to view ?..I am not sure of any condition to put in the intial time of querying.
	View 5 Replies
    View Related
  
    
	
    	
    	
        Apr 12, 2013
        At moment we use range-hash partitioning of a large dimension table (dimension model warehouse) table with 2 levels - range partitioned on columns only available at bottom level of hierarchy - date and issue_id.
Result is a partition with null value - assume would get a null partition in large fact table if was partitioned with reference to the large dimension.Large fact table similarly partitioned date range-hash local bitmap indexes 
Suggested to use would get automatic partition-wise joins if used reference partitioningWould have thought would get that with range-hash on both dimension.
	View 3 Replies
    View Related
  
    
	
    	
    	
        Oct 18, 2010
        Scenario:
Our application is using a two instance, one for the live active data and the other for the reports data. We have a process which moves the data from the live instance to reports instance every night. In a single db environment the process is working without any issues. However when we move to the RAC environment the reports db's (insert) in large table get locked and we are unable to insert data to the reports db.
What we are performing is:
Insert into my_table_rpt select * from may_table_live@db_link_to_livedb;
Issues: 
my_table_rpt get locked
We have found the workaround by disable locking in destination and subsequent to the insert enable locking
ALTER TABLE my_table_rpt DISABLE TABLE LOCK;
Insert the data to the reports database table 
Then 
ALTER TABLE my_table_rpt ENABLE TABLE LOCK
Question:
Why does the large destination table (my_table_rpt) get locked in the RAC environment?
	View 2 Replies
    View Related
  
    
	
    	
    	
        Mar 28, 2011
        I have several large tables in the live system! Those table are store historical information.
current situation:
Now, A table record was 129 million rows.
Every month added 4.5M records to this table.
This table data size 17GB and index size 28GB.
I have only 30 GB available free space on disk!
How to split this table to small pieces (partition table by month)?
What is the best approach?
I would like to do partitioning on this table month by month.
	View 12 Replies
    View Related
  
    
	
    	
    	
        Aug 8, 2013
        We have data archive scripts, these scripts move data for a date range to a different table. so the script has two parts first copy data from original table to archive table; and second delete copied rows from the original table. The first part is executing very fast but the deletion is taking too long i.e. around 2-3 hours. The customer analysed the delete query and are saying the script is not using index and is going into full table scan. but the predicate itself is the primary key,More info below
CREATE TABLE "APP"."MON_TXNS"    (    "ID_TXN" NUMBER(12,0) NOT NULL ENABLE,     "BOL_IS_CANCELLED" VARCHAR2(1 BYTE) DEFAULT 'N' NOT NULL ENABLE,     "ID_PAYER" NUMBER(12,0),     "ID_PAYER_PI" NUMBER(12,0),     "ID_PAYEE" NUMBER(12,0),     "ID_PAYEE_PI" NUMBER(12,0),     "ID_CURRENCY" CHAR(3 BYTE) NOT NULL ENABLE,     "STR_TEXT" VARCHAR2(60 CHAR),     "DAT_MERCHANT_TIMESTAMP" DATE,     "STR_MERCHANT_ORDER_ID" VARCHAR2(30 BYTE),     "DAT_EXPIRATION" DATE,     "DAT_CREATION" DATE,     "STR_USER_CREATION" VARCHAR2(30 CHAR),     "DAT_LAST_UPDATE" 
[Code]...
 Data is first moved to table in schema3.OTW. and then we are deleting all the rows in otw from original table. below is the explain plan for delete  
SQL> explain plan for  2  delete from schema1.mon_txns where id_txn in (select id_txn from schema3.OTW); 
Explained. SQL> select * from table(dbms_xplan.display); 
PLAN_TABLE_OUTPUT--------------------------------------------------------------------------------------------------------------------------------------------
Plan hash value: 2798378986
 -------------------------------------------------------------------------------------
| Id  | Operation              | Name       | Rows  | Bytes | Cost (%CPU)| Time     |
-------------------------------------------------------------------------------------|   0 | DELETE STATEMENT       |            |  2520 |   233K|    87   (2)| 00:00:02 ||   1 |  DELETE                | MON_TXNS   |       |       |            |          ||*  2 |   HASH JOIN RIGHT SEMI |            |  2520 |   233K|    87   (2)| 00:00:02 ||   3 |    INDEX FAST FULL SCAN| OTW_ID_TXN |  2520 | 15120 |     3   (0)| 00:00:01 ||   4 |    TABLE ACCESS FULL   | MON_TXNS   | 14260 |  1239K|    83   (0)| 00:00:02 |
-------------------------------------------------------------------------------------
 PLAN_TABLE_OUTPUT
-------------------------------------------------------------------------------------------------------------------------------------------- 
Predicate Information (identified by operation id):
--------------------------------------------------- 
	View 6 Replies
    View Related
  
    
	
    	
    	
        Oct 8, 2013
        I have a report with single row having large number of columns . I have to use a scroll bar to see all the columns. Is it possible to design report in below format(half columns on one side of page, half on other side ofpage : 
Column1DataColumn11DataColumn2DataColumn12DataColumn3DataColumn13DataColumn4DataColumn14DataColumn5DataColumn15DataColumn6DataColumn16DataColumn7DataColumn17DataColumn8DataColumn18DataColumn9DataColumn19DataColumn10DataColumn20Data I am using Apex 4.2.3 version on oracle 11g xe.
	View 2 Replies
    View Related
  
    
	
    	
    	
        Aug 15, 2011
        I have two design alternatives and need to understand how expensive (speed) is one of them against the other for a medium size table (100K-200K records):
create table xyz
(
f1 number not null,
f2 varchar2(20) not null,
f3 number not null,
f4 varchar2(50),
[code]....
the idea is to optimize the design by using a PK instead of the 3 keys and there is a debate that searching a unique index field(2nd scenario) is of the same speed than searching a PK field (1st scenario).
	View 5 Replies
    View Related
  
    
	
    	
    	
        Oct 9, 2012
        I have a table Product as;
desc product
Name                    Null              Type                             
-------------------------------------------------------------- 
PRODUCT_ID            NOT NULL            NUMBER                             
INGREDIENT                              VARCHAR2(20)
The data in Ingredient is separated by ','.
PRODUCT_ID             INGREDIENT           
---------------------- -------------------- 
1                      A,B,C                
2                      A,D                  
3                      E,F                  
I need to write a sql statement which will retrieve a pair of product and ingredient in each row as;
PRODUCT_ID             INGREDIENT           
---------------------- -------------------- 
1                      A                
1                      B
1                      B
2                      A  
2                      D                
3                      E  
3                      F
 write this sql ?
	View 1 Replies
    View Related
  
    
	
    	
    	
        Aug 24, 2012
        How block splitting will happen in oracle block.
Suppose, I am having Oracle BLOCK_SIZE of 16k and my Linux OS level BLOCK SIZE is 4k. then How 16k oracle block will store in OS level? and 
What will be the internal block splitting process?
	View 10 Replies
    View Related
  
    
	
    	
    	
        Feb 19, 2008
        I was wondering if there is an Oracle function available to split a string based on a delimiter character.  For example, if I have a table consisting of:
HOST
-----
emerald.test.com
ruby.test.com
diamond.test.com
I would like to only return ('emerald', 'ruby', 'diamond') by getting all data leading up to the first '.' character.
	View 1 Replies
    View Related
  
    
	
    	
    	
        Feb 18, 2013
        I need  to split the given string into muliple sub strings based  on one special character  
Ex :  Speace  is Special character 
with  data as (
select 'ab cd ef gh ' from dual )  
select  *  from  data 
Required Output  : 
ab
cd
ef
gh 
	View 3 Replies
    View Related
  
    
	
    	
    	
        Mar 26, 2010
        Aim: Architecture change in existing application
Domain: Health Care
Background: There are 2 application ( Front end: one in oracle forms - deals with accounts module and another in some legacy application - deals with patient, clinical and diagnose module) using and sharing the same Oracle 9i database.
Patient related modules are moved into another database ( java as a front end, oracle 10g as backend ) which is normalized - eliminating duplicate tables and column, also its tables and columns names are not matching with existing (patient)system.
Now the requirement is making the existing application related only to Accounts module ( having complicated business logic written in packages )  to work as it is without changing the code, design drastically.
Questions:
1. Now how best this task can be completed without affecting existing Accounts system drastically ( with minimal changes )?
2. what are the possible best approach to achieve this ?
3. what are the best way for communicating the 2 DB in this scenario ( may be creating synonym, views etc ) ?
4. What are challenges that needs to be addressed ?
	View 1 Replies
    View Related
  
    
	
    	
    	
        Feb 28, 2013
        I have string like 'PRASAD,ALLEN,STEWART,SMITH'.
LIKE
COL1    COL2    COL3      COL4
-------------------------------
PRASAD ALLEN    STEWART   SMITH
I want to store the data into columns using SELECT statement only 
	View 7 Replies
    View Related
  
    
	
    	
    	
        Oct 20, 2010
        I have a table which has a column that stored concatenated data. 
Sample test case is as below:
SQL> create table tst (
  2   col1 varchar2(20));
SQL> insert into tst values  ('one,two,three');
1 row created.
SQL> commit;
Commit complete.
Is there any way i could write a sql to split the text of this column into rows? Sample output im expecting is as below
col1
-------
one
two
three
	View 13 Replies
    View Related
  
    
	
    	
    	
        Sep 14, 2012
        I need to join ISSUED_REMOVED Table with ITL Table. having each quantity each row. 
Eg. If a unit Serial no '354879019900009' has a part (1015268) issued 8 times and then unissued 4 times so finally the part was issued 4 times. so I need 4 rows to show for each qty 1 for that part and unit serial number. 
-- ITL Table
Create table ITL_TEST (
ITEM_SERIAL_NO, ITEM_BCN, ITEM_ID, ITEM_PART_NO, OPER_ID, 
ISSUED_REMOVED_PARTNO, ISSUED_REMOVED_QUANTITY, QUANTITY, SHIPMENT_ID)
[code]....
-- Issued Removed table
create table ISSUED_REMOVED_ITEM
(REPAIRED_ITEM_ID, ISSUED_REMOVED_ITEM_ID, ISSUED_PART_ID, OPER_ID, ISSUED_REMOVED_QUANTITY)
as select 
122013187, 1323938, 1015268, 308, 2 from dual union all select
122013187, 1323939, 1015269, 308, 2 from dual union all select
122013187, 1323940, 1015268, 308, 2 from dual union all select
[code]....
-- The way I need to join the Issued_Removed Table
select * from ITL_TEST ITL 
left join 
issued_removed_item iri
on iri.REPAIRED_ITEM_ID = ITL.ITEM_ID --ITL.ITEM_ID --rlsn2.item_id --126357561 
and iri.oper_id = 308 --in ( 308, 309)
[code]....
	View 1 Replies
    View Related