Performance Tuning :: Correct Method To Determine Table Actual Size
			Aug 9, 2012
				Which is the correct method to calculate actual data size in a table? becaue when I serach in google, I saw the  below line. 
"Oracle thumb rule says (actual space required for a table + 30 % space) will calculate the original space requirement for a table."
Method 1: 
actual space = num_rows*avg_row_len
Method 2:
actual space = (Num of rows in a table) * (Avg_row_len) + ((Num of rows in a table) * (Avg_row_len)* 0.3)
	
	View 8 Replies
  
    
		
ADVERTISEMENT
    	
    	
        Oct 20, 2010
        There is a simple way to increase the performance of a query by reducing the row-size of the table it hits. I used it in the past by dividing the table into smaller parts and querying respective smaller table in each query. 
 what is this method called ? just forgot the method and can't recall it. what this type of row-reduction optimization is called ?
	View 6 Replies
    View Related
  
    
	
    	
    	
        May 9, 2011
        Objective : To find solution to archieve data from 2 big tables  which is occupying maximum size in the data base. With current data (From Jan 2005 to Sept 2011) it has records as mentioned below: 
                      
transaction -  41687927
trnansaction_dtl  -  83945934 
We need to load data and run monthly batches from October 2011 to current month which will increase this space. 
1. Issue is there will not be having so much space.
2. Maintenance of such table is diffcult now.Also there is huge impact on performance. Can we think of partitioning the table base on date aswe query 1st table based on certain date range? 
3. Most of  reports use this table and creating performances issues
	View 30 Replies
    View Related
  
    
	
    	
    	
        Aug 9, 2012
        We are investigating performance of SQL executions on a database server and we suspect I/O on the server is an issue
For example one particular statement accesses one row during execution (index access) and still takes 2.4 seconds out of which it does I/O for 1.9 seconds
which of the following sections in the AWR will give us the correct information about the I/O, it is slow or not? 
1)
Load Profile
Logical reads per second
Physical reads per second
2)
Top 5 Timed Foreground Events
waits / time(s) for events like "db file sequential/scattered read"
average wait(ms) for events like "db file sequential/scattered read"
3)
Foreground Wait Events
db file sequential read 
db file scattered read 
4)
Wait Event Histogram
%of waits <1ms <2ms
Disk file operations I/O
db file sequential read
db file scattered read
5)
Wait Event Histogram Detail (64 msec to 2 sec)
Wait Event Histogram Detail (4 sec to 2 min)
6)
IOStat by Function summary
Buffer Cache Readsreads per sec
7)
File IO Stats
	View 5 Replies
    View Related
  
    
	
    	
    	
        Feb 14, 2013
        We have a table emp_details with 23772889 records. Our requirement is to increase few of the columns size in the table emp_details. We are following the below alter statement which is taking around 2 hours of time. 
ALTER TABLE emp_details 
MODIFY
(
address                   char(90)                    
 ,department                char(30)                    
)
/ 
Is there any way to improve the above query performance?
	View 2 Replies
    View Related
  
    
	
    	
    	
        Jul 24, 2013
        determine if a function is worth pinning in memory? I want to come up with a percentage, implying that if the function is already im memory 80%+ of the time then it is not worth it.
	View 5 Replies
    View Related
  
    
	
    	
    	
        Mar 28, 2012
        How to find the tables starting with smallest size and vice versa in schema level and database level?
	View 4 Replies
    View Related
  
    
	
    	
    	
        Jun 20, 2012
        we have 96GB Memory on the UNIX server and 85% of its usage shows oracle processes I want to determine which Oracle processes are taking most of the memory
SGA is around 36G
SGA_TARGET is 40G
PGA is around 4G
the total of around 40-45 GB of usage is understandable but what other oracle process are chewing up the remaining 30-40 GB on the server is not known 
load averages:  7.35,  6.46,  6.15;                    up 248+11:33:21                     12:25:03
2202 processes: 2196 sleeping, 1 zombie, 5 on cpu
CPU states: 83.8% idle, 10.5% user,  5.8% kernel,  0.0% iowait,  0.0% swap
Memory: 96G phys mem, 15G free mem, 128G total swap, 128G free swap
PID USERNAME LWP PRI NICE  SIZE   RES STATE    TIME    CPU COMMAND
21720 oracle   258   0    0   40G   40G cpu/48 215:28  2.04% oracle
10709 oracle     1   0    2 1816K 1448K cpu/9    0:02  0.90% res_conf_email_
[code]......
	View 6 Replies
    View Related
  
    
	
    	
    	
        Aug 10, 2011
        I am running Oracle 10.2.0.1.0 on MS Windows 2003 server 64-bit with 16G RAM.
Here is the findings for my Oracle database.
SQL> select * * from v$sgainfo;
NAME      BYTES RES
-------------------------------- ---------- ---
Fixed SGA Size       1293560 No
Redo Buffers         7094272 No
Buffer Cache Size  830472192 Yes
[code]...
I find that the SGA component "Buffer Cache" is decreasing from the start "1.8G" and down to now 0.8G. On the other hand, the component "Shared Pool" is increasing from the start 0.3G to now 1.2G. I noticed that there are 100 operations of shrinking of "Buffer cache" and growth of "Shared Pool" in Oracle every day.Is it a indicator that I should raise up the SGA_MAX_SIZE?
I tried to increase the SGA_MAX_SIZE to 4G. But I cannot start the Oracle afterward.Is it a limitation of MS Windows(OS) or Oracle?I set the SGA_MAX_SIZE to 3G. This time, I can startup Oracle.What is the optimum/maximum I can set to SGA_MAX_SIZE?Is there any adverse effect/concern when setting the SGA_MAX_SIZE more than 2G?
	View 6 Replies
    View Related
  
    
	
    	
    	
        Jun 18, 2012
        In one of our envirnoment i could see the redo size is high.Trying to understand why this is more 
	View 18 Replies
    View Related
  
    
	
    	
    	
        Apr 6, 2011
        The REDO log file size is important DB performance issues when DB is run archivelog mode.If DB run noarchivelog mode, REDO log file size not impact to DB performance.
	View 3 Replies
    View Related
  
    
	
    	
    	
        Feb 10, 2011
        I would like to make a change on the live system!I have read a book and found a information about REDO log file size is impact on DB performance.My DB current log file size is 100 MB. But, Oracle 10g's Redo Logfile Sizing Advisor offer the optimal log file size is 1845 MB.What REDO log file size is best for my Oracle database?
#Optimal log file size:
select optimal_logfile_size 
from v$instance_recovery
----------------------------
OPTIMAL_LOGFILE_SIZE
1842
[code]....
	View 9 Replies
    View Related
  
    
	
    	
    	
        Apr 22, 2013
        I have got the following error yesterday
  
ORA-01555 caused by SQL statement below (SQL ID: fdxcyoin67ty8t, Query Duration=380128 sec, SCN: 0x0229.ff00afd0):
following are the existing settings
SQL> show parameter undo
NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
undo_management                      string      AUTO
undo_retention                       integer     96000
undo_tablespace                      string          undo
[code]....
following are the details from v$undostat
select begin_time, end_time, undotsn, undoblks, maxquerylen, maxqueryid, activeblks, unexpiredblks, expiredblks, tuned_undoretention from v$undostat 
where trunc(begin_time)=trunc(sysdate)-1 order by begin_time;
BEGIN_TIME     END_TIME          UNDOTSN   UNDOBLKS MAXQUERYLEN MAXQUERYID    ACTIVEBLKS UNEXPIREDBLKS EXPIREDBLKS TUNED_UNDORETENTION
-------------- -------------- ---------- ---------- ----------- ------------- ---------- ------------- ----------- -------------------
21-04-13 00:08 21-04-13 00:18          1      12733      378446 duqnawh32hp4u      91152       7068448      225440              345600
21-04-13 00:18 21-04-13 00:28          1       8951      379047 duqnawh32hp4u      99344       7072800      225440              345600
21-04-13 00:28 21-04-13 00:38          1      14073      379650 duqnawh32hp4u      90128       7075872      234656              345600
[code]....
Following are the details in AWR report (00:00 til 01:00 of 21-Apr-2013)  .... not thet the error was produced at 00:42
Undo Segment Summary                DB/Inst: DBCPY/dbcpy01  Snaps: 18853-18854
-> Min/Max TR (mins) - Min and Max Tuned Retention (minutes)
-> STO - Snapshot Too Old count,  OOS - Out of Space count
-> Undo segment block stats:
-> uS - unexpired Stolen,   your - unexpired Released,   uU - unexpired reUsed
[code]....
Undo Advisor information taken 'now' is as following
SQL> select dbms_undo_adv.longest_query(sysdate-2,sysdate) from dual;
DBMS_UNDO_ADV.LONGEST_QUERY(SYSDATE-2,SYSDATE)
----------------------------------------------
379650
SQL> select dbms_undo_adv.required_retention from dual;
[code]....
In above situation what should be my first choice (assuming increasing space is not an issue) - increase undo tablespace or increase undo retention?  
If latter is the choice then what should be the value? Because as I understand present 96000 value is taken as lower limit and because of auto tuning the actual value (TUNED_UNDORETENTION) being used was 345600 In that case shall I set it to something > max(maxquerylen) i.e 379,650 + X?Or I shall increase the undo tablespace size?
From Undo Advisor output it looks to me that even if I increase the undo retention to 379650 current undo size will be able to support it (may be at the expense of DMLs)Is that right?
	View 13 Replies
    View Related
  
    
	
    	
    	
        Nov 25, 2011
        All the analysis till now on our system proves that our system is clearly I/O bound and db sequential read is the biggest culprit. 
We have even identified the index which is being affected by sequential read. I am thinking of creating a new tablespace with 32K blocksize (currently all table spaces are 8k) and migrate this index to the new space. That way, Oracle will have to do less number of reads to get the required data. 
But is there anything wrong in having just one tablespace with a differnt block size? Or is there anything that I have to be watchful about while doing it?
	View 14 Replies
    View Related
  
    
	
    	
    	
        Feb 18, 2013
        The db is 11.2.0.3 on a linux machine.I would like to know the "fetch size" of an application, but I was not able to find any related meteris in v$statname.
The application configruation is invisible to me.Do I need to do some calculations based on statistic metrics from v$statname?
If so, what meteris should be considered for the assumption for "fetch size" ?
The following is from manual, but the application configuration is invisible to me.
[URL]
Setting the Fetch Size
The following methods are available in all Statement, PreparedStatement, CallableStatement, and ResultSet objects for setting and getting the fetch size:
•void setFetchSize(int rows) throws SQLException
•int getFetchSize() throws SQLException
	View 4 Replies
    View Related
  
    
	
    	
    	
        Apr 3, 2008
        i got a table and it had 5000 rows of data...ive deleted around 2000 to decrease the db size but i have no success. My harddrive is still showing the same size with no increase in mb. 
I've looked at shrink etc methods but some are not compatible with 8i. 
I take it the db is still reserving that those deleted rows thinking it may be used again which is the reason for no increase in space.
	View 1 Replies
    View Related
  
    
	
    	
    	
        Oct 31, 2011
        I have two tables with 113M records in DWH_BILL_DET &  103M in prd_rerate_chg_que and Im running following merge query, which is running for 13 hrs to update records, which is quiet longer time. 
SQL> explain plan for MERGE /*+ parallel (rq, 16) */
INTO DWH_BILL_DET rq
USING (SELECT rated_que_rowid,
detail_rerate_flag_code,
rerate_sel_key,
[code].....
	View 39 Replies
    View Related
  
    
	
    	
    	
        Aug 10, 2012
        Suppose tablespace allocation_type is system then how oracle determines the initial extent and max extent size?
	View 4 Replies
    View Related
  
    
	
    	
    	
        Feb 6, 2011
        I am trying to update columns of Table A with the columns of Table B. Both these tables have 60,000 rows each. I tried this operation using following 2 queries:
Query 1
Update TableA A
set 
(A.col1,A.col2,A.col3)=(select B.col1,B.col2,B.col3
from TableB
where A.CODE=B.CODE)
Query 2
Update TableA A
set
(A.col1,A.col2,A.col3)=(select B.col1,B.col2,B.col3
from TableB
where A.CODE=B.CODE)
where exists
A.code = (select B.code
from TableB B
where A.code=B.code) 
When i execute these two above queries, it keeps executing indefinitely. 
	View 4 Replies
    View Related
  
    
	
    	
    	
        Jun 24, 2011
        Below query is taking a long time...
select gam.SOL_ID,COUNT(gam.FORACID) from gam,smt where 
gam.ACID=smt.ACID and gam.ACID NOT IN(select ACID from imt)  and
gam.SCHM_TYPE in('SBA','CCA','CAA','ODA') and GAM.ACCT_CLS_FLG='N' and
gam.SOL_ID IN(select SOL_ID from IMT) group by gam.SOL_ID
/
attached is the explain plan. 
in which index on IMT table is not used. And the query is doing a FTS on IMT table. What needs to be done to avoid FTS on IMT table.
	View 10 Replies
    View Related
  
    
	
    	
    	
        Jun 28, 2010
        What are the factors that decide on which column we should partition the table and which partition method we should chose.
	View 2 Replies
    View Related
  
    
	
    	
    	
        Aug 3, 2010
        I am using one script to delete the records from a table, its taking 1hr to delete.
declare
cursor c1 is select ownerid,ownertype from nightly_metric_projects
;
v1 c1%rowtype;
open c1;
loop
fetch c1 into v1;
exit when c1%notfound;
DELETE FROM DGT_ITEMEFFORTDATA                                  WHERE OWNERTYPE = c1.OWNERTYPE
AND OWNERID = c1.OWNERID;
end loop;
close c1;
commit;
         
nightly_metric_projects--1200 records
DGT_ITEMEFFORTDATA--13200000 
	View 14 Replies
    View Related
  
    
	
    	
    	
        Aug 4, 2010
        I have normal tables with hugh Data and would like to increase the performace by following means:
1) Add a new column in each table. Say this column Name is IS_LIVE. This new column have only two value 1 ( LIVE ) OR 0 ( NOT LIVE ).
2) Change the normal tables to Partitioned table. There would be only two partitioned in all the table. The partitioned key column would be IS_LIVE and both partitioend recrods would be in two different tablespace.
3) Added a POLICY function to these partitioned table to Always add a Query Predicate of '1' to all queuries.
I am interested to know that what kind of Indexes ( Global Or local ) would be suitable for these kind of Design.Is there any use of having Local index on IS_LIVE.Please note that Primary Key doesnot have this new column in it.
	View 10 Replies
    View Related
  
    
	
    	
    	
        Sep 26, 2012
        what analyzing a table does to existing indexes? Do I need to rebuild the indexes after dbms_stats.gather_table_stats command ?
	View 4 Replies
    View Related
  
    
	
    	
    	
        Jun 17, 2011
        We have few tables in our production database which are havoc in size and will increase in size in future too so as part of the corrective measures , we have jotted down the below 3 methods to manage the size of those tables :-
1> Partitioning the table and take the export of identified partitions and after that, truncate those partition.
2> Creating history tables and remove not so current data from the original table to history table.
	View 3 Replies
    View Related
  
    
	
    	
    	
        Dec 29, 2011
        I have tried below steps for removing the table fregmentation but for some table i am not getting good result here.
1. It will collect the data which are having more than 100MB fragmentation.
select owner,table_name,blocks,num_rows,avg_row_len,round(((blocks*8/1024)),2)||'MB' "TOTAL_SIZE", round((num_rows*avg_row_len
/1024/1024),2)||'Mb' "ACTUAL_SIZE", round(((blocks*8/1024)-(num_rows*avg_row_len/1024/1024)),2) ||'MB' "FRAGMENTED_SPACE" from
 dba_tables where owner in('a','b','c','d') and round(((blocks*8/1024)-(num_rows*avg_row_len/1024/1024)),2)
 > 100 order by 8 desc;
2. then move the object(table) to the same tablespace.
alter table abc move;
alter table bcd move;
alter table efg move;
3. also rebuild the dependent objects.
alter index abc_PK rebuild online;
4. Then analyze the table which are having more than 100MB of fragmentation.
exec dbms_stats.gather_table_stats('a','abc');
exec dbms_stats.gather_table_stats('b','bcd');
exec dbms_stats.gather_table_stats('c','cdf');
after that when check the table fragmentation, i am getting the same result, which i have collected from the 1st query. 
	View 7 Replies
    View Related
  
    
	
    	
    	
        Apr 27, 2012
        From the below query i found that there are some stale stats for 3 tables.
=================================
select table_name, stale_stats, last_analyzed 
from dba_tab_statistics 
where owner= 'SYSADM' and stale_stats='YES'
order by last_analyzed desc
I collect stats for those above 3 tables with dbms_stats.gather_table_stats().But no luck.After collection of stats immediately I ran the above query.But still it is showing there are stale stats for 3 tables.
how can I change "STALE-STATS" status, so that optimizer can use the updated stats eficiently.
	View 3 Replies
    View Related
  
    
	
    	
    	
        Sep 4, 2011
        If a table(have a primary key) is empty(after truncate),the sql of dml(insert,update) is very quickly,but if the table have many rows about 10,000,000 rows, the dml is very slowly,why?
	View 6 Replies
    View Related
  
    
	
    	
    	
        Aug 8, 2013
        Is it possible for the DBMS_STATS "LIST STALE" command to show a stale partition but NOT have its table show as stale?
I had a scenario where the table itself AND 1 partition showed as stale. I ran a fnd_stats gather table stats just on that 1 partition. Once it was completed it showed the partition to no longer be stale. it also showed that the table was no longer stale. so I guess I do not need to run stats on the whole table as well?
so if this is the case, when would I need to run stats on the full partitioned table if running it on the partitions themselves removes the staleness of the table?
	View 3 Replies
    View Related
  
    
	
    	
    	
        Mar 19, 2012
        1.2 million chained rows, 1.7 million blocks, etc.  Initial extent for this table is 64k and next 1 mb.  I would try to calculate this out better for efficiency and performance.  This will not be efficient as it stands. calculate the size.
	View 14 Replies
    View Related