Performance Tuning :: Can Use Oracle Hint To Use Index In A Query Which Uses UNION
			Mar 31, 2011
				I have a SQL query where I am making UNION of two select statements. The table that I am joining in each select statement have indexes defined for those tables.
Now the UNION of the two select statements again in enclosed in an inline view , from which I fetching my final field values.
The select statements inside the inline view returns huge number of row (like 50 million rows).
The whole query fails with time out.
Is there a way to pass Oracle Hints so that Oracle uses indexes?
	
	View 1 Replies
  
    
	ADVERTISEMENT
    	
    	
        Mar 31, 2011
        I have a SQL query where I am making UNION of two select statements. The table that I am joining in each select statement have indexes defined for those tables.
Now the UNION of the two select statements again in enclosed in an inline view , from which I fetching my final field values.
The select statements inside the inline view returns huge number of row (like 50 million rows).
The whole query fails with time out.
How can I optimize this query further?
Is there a way to pass Oracle Hints so that Oracle uses indexes?
	View 4 Replies
    View Related
  
    
	
    	
    	
        Jan 27, 2012
        We have a large customer table so first thought was to partition.Also we see two union alls in the plan - can we introduce parallelism? Below is the plan - have attached a text file if difficult to read
SELECT V_IDENTIFIER_LOOKUP.UID_V_IDENTIFIER_LOOKUP AS "UID",
V_IDENTIFIER_LOOKUP.ABA,        V_IDENTIFIER_LOOKUP.ADDRESS1,
V_IDENTIFIER_LOOKUP.ADDRESS2,        V_IDENTIFIER_LOOKUP.ADDRESS3,
  V_IDENTIFIER_LOOKUP.ADDRESS4,        V_IDENTIFIER_LOOKUP.ALIAS,
V_IDENTIFIER_LOOKUP.CITY,        V_IDENTIFIER_LOOKUP.COUNTRYCODE,
  V_IDENTIFIER_LOOKUP.CUST_CODE,        V_IDENTIFIER_LOOKUP.CUST_NAME,
      V_IDENTIFIER_LOOKUP.HEAD_OFFICE_IN,
V_IDENTIFIER_LOOKUP.IDENTIFIER,
V_IDENTIFIER_LOOKUP.IDENTIFIER_TYPE,
 [code]...
	View 1 Replies
    View Related
  
    
	
    	
    	
        Sep 25, 2013
         select 
serialnumber from product where productid in 
(select /*+ full parallel(producttask 16) */productid from producttask where 
startedtimestamp > to_date('2013-07-04 00:00:00', 'YYYY-MM-DD HH24:MI:SS') 
and startedtimestamp < to_date('2013-07-05 00:00:00', 'YYYY-MM-DD HH24:MI:SS') 
and producttasktypeid in 
[code]....
Explain plan output:
 Plan hash value: 2779236890
-----------------------------------------------------------------------------------------------------------------------------------------
| Id  | Operation   | Name| Rows| Bytes | Cost (%CPU)| Time| Pstart| Pstop |
-----------------------------------------------------------------------------------------------------------------------------------------
|   0 | SELECT STATEMENT   ||     1 |    29 |  9633M  (8)|999:59:59 |||
|*  1 |  FILTER    ||||     ||||
|   2 |   PARTITION RANGE ALL   ||   738M|    19G|  6321K  (1)| 21:04:17 |     1 |  6821 |
[code]....
Predicate Information (identified by operation id):
---------------------------------------------------
   1 - filter( EXISTS (<not feasible>)
   4 - filter("PRODUCTID"=:B1)
   5 - filter(ROWNUM<100)
  12 - access("MODELID"=:B1)
[code]....
Note:  - SQL profile "SYS_SQLPROF_014153616b850002" used for this statement
	View 2 Replies
    View Related
  
    
	
    	
    	
        Oct 20, 2011
        does parallel hint in query can create bottleneck/Slowdown/crash database..??
	View 4 Replies
    View Related
  
    
	
    	
    	
        Nov 19, 2010
        I have a query which had a join:
a.c1=b.c1 and a.c2=@var
where @var is user supplied input at runtime...We had a index on a.c2 . The CBO would use this index to generate an opitimised query plan.We found some records from table "b" were dropping due to inner join. So we made a change in join. It'd be like
a.c1(+)=b.c1 and nvl(a.c2,@var)=@var
This query is no longer using the index, instead its doing a full table scan causing the query to slowdown.I have tried creating index on nvl(a.c2,'31-dec-9999')
But the CBO won't use it.Anyway to create index on this col so that full table scan can be avoided?
	View 2 Replies
    View Related
  
    
	
    	
    	
        Sep 9, 2010
        Oracle UNION ALL performance issue: when I try to run below SQL query separately SQL part1 and SQL part2 it takes some seconds only but if I run together with group by and without group by it take much time.
SELECT AVG(date_completed-login_date),to_char(to_date(login_date), 'YYYY') as wYear FROM
(
SELECT test.date_completed 'date_completed',sample.login_date 'login_date')
FROM sample test
where (some conditions) ) ---SQL part 1
UNION ALL
[code]...
	View 33 Replies
    View Related
  
    
	
    	
    	
        Jul 14, 2010
        I have a query with FULL hint that is behaving in a strange manner. The query fetches around 700000 of data. Sometimes it fetches the data with the hint and sometimes it does not fetch any data with the hint and then I have to remove the hint and have to fetch the data. Below is the query,
select  /*+ FULL(COMP_TM) FULL(TRANS_TM) FULL(INVC_TM) */
          CUST_BE_ID     ,
            DISTR_BE_ID    ,
            FG_BE_ID         ,
            KIT_BE_ID        ,
            BG_ID_NO_BE_ID         ,
   [code]....
The statistics gathering activity of FACT_DLY_ALGND_SLS table takes around 5 hours to complete. It is a range partitioned table with subpartitions.
	View 14 Replies
    View Related
  
    
	
    	
    	
        May 18, 2012
        I am working with following select clause: 
select distinct S.ID ID
from
ods.hso_Scheduled H,
ods.SO_SCHEDULED S
where 
S.insertion_date >= to_date('01-DEC-2011') and S.insertion_date < to_date('01-FEB-2012')
and H.ID=S.ID 
Both the involved tables, HSO_SCHEDULED is having 15 million records and SO_SCHEDULED table is having 7 million records.
I have created following indexes on these tables:
Indexes on SO_SCHEDULED:
Index name                      Column name
SS_IDX1ID, SO_SUB_ITEM__ID
SS_IDX2INSERTION_DATE
SS_IDX3ID, INSERTION_DATE
SS_IDX4ID, SO_SUB_ITEM__ID, INSERTION_DATE
SO_SCHEDULED_ID_PKID
Indexes on HSO_SCHEDULED:
HSS_IDX1ID, SO_SUB_ITEM__ID, LAST_UPDATING_DATE
HSS_IDX2ID, LAST_UPDATING_DATE
HSS_IDX3ID
My problem is despite of having relevant indexes present, my query is not hitting them and hence the performance is very bad.
Explain Plan:
Execution Plan
----------------------------------------------------------
Plan hash value: 574170360
--------------------------------------------------------------------------------------------------------------------------------
| Id  | Operation                 | Name          | Rows  | Bytes |TempSpc| Cost (%CPU)| Time     |    TQ  |IN-OUT| PQ Distrib |
--------------------------------------------------------------------------------------------------------------------------------
|   0 | SELECT STATEMENT          |               |   814K|    38M|       |  9574   (1)| 00:02:15 |        |      |            |
|   1 |  PX COORDINATOR           |               |       |       |       |            |          |        |      |            |
|   2 |   PX SEND QC (RANDOM)     | :TQ10002      |   814K|    38M|       |  9574   (1)| 00:02:15 |  Q1,02 | P->S | QC (RAND)  |
|   3 |    HASH UNIQUE            |               |   814K|    38M|   185M|  9574   (1)| 00:02:15 |  Q1,02 | PCWP |            |
|*  4 |     HASH JOIN             |               |  2653K|   124M|       |  9564   (1)| 00:02:14 |  Q1,02 | PCWP |            |
|   5 |      PX JOIN FILTER CREATE| :BF0000       |   814K|    22M|       |  3903   (1)| 00:00:55 |  Q1,02 | PCWP |            |
|   6 |       PX RECEIVE          |               |   814K|    22M|       |  3903   (1)| 00:00:55 |  Q1,02 | PCWP |            |
|   7 |        PX SEND HASH       | :TQ10000      |   814K|    22M|       |  3903   (1)| 00:00:55 |  Q1,00 | P->P | HASH       |
|   8 |         PX BLOCK ITERATOR |               |   814K|    22M|       |  3903   (1)| 00:00:55 |  Q1,00 | PCWC |            |
|*  9 |          TABLE ACCESS FULL| SO_SCHEDULED  |   814K|    22M|       |  3903   (1)| 00:00:55 |  Q1,00 | PCWP |            |
|  10 |      PX RECEIVE           |               |    14M|   272M|       |  5654   (1)| 00:01:20 |  Q1,02 | PCWP |            |
|  11 |       PX SEND HASH        | :TQ10001      |    14M|   272M|       |  5654   (1)| 00:01:20 |  Q1,01 | P->P | HASH       |
|  12 |        PX JOIN FILTER USE | :BF0000       |    14M|   272M|       |  5654   (1)| 00:01:20 |  Q1,01 | PCWP |            |
|  13 |         PX BLOCK ITERATOR |               |    14M|   272M|       |  5654   (1)| 00:01:20 |  Q1,01 | PCWC |            |
|  14 |          TABLE ACCESS FULL| HSO_SCHEDULED |    14M|   272M|       |  5654   (1)| 00:01:20 |  Q1,01 | PCWP |            |
--------------------------------------------------------------------------------------------------------------------------------
Predicate Information (identified by operation id):
---------------------------------------------------
4 - access("H"."ID"="S"."ID")
9 - filter("S"."INSERTION_DATE">=TO_DATE(' 2011-12-01 00:00:00', 'syyyy-mm-dd hh24:mi:ss') AND
 "S"."INSERTION_DATE"<TO_DATE(' 2012-02-01 00:00:00', 'syyyy-mm-dd hh24:mi:ss'))
	View 6 Replies
    View Related
  
    
	
    	
    	
        Aug 28, 2013
        Does parallel hint works in cursor queries? The  cursor query is something like :
cursor c is 
select /*+ parallel(s,8) */
from table ref_tab s ---- >>
<where condition>;
The table ref_tab hold data for a single day at any point of time and gets truncate before loading the next days data.On average the table holds around 7 million rows and doesn't contains any index (think that's fine as all together we are loading the whole set).And, we are using bulk logic with save exceptions to open the cursor and load the data into the target table.
	View 13 Replies
    View Related
  
    
	
    	
    	
        Aug 16, 2012
        I have an APP that truncates tables and loads data, which in turn makes the stats stale. I ran the query advisor (see attachment) and of course it ecommends running stats or accept a profile.I really don't want to do that as it may cause a load on my DB.
In turn, I would like to consider having my APP team change the query to pass a hint to use the best query plan.syntax to pass the hint to emulate good attached plan? Or is this a bad way to proceed?
select /* INDEX FAST FULL SCAN PK_PLACEMENT_REQUEST_QUEUE */
sum(lastshares) as "ROSEN"
from nyeo.fix_exec_reports fer, nyeo.placement_request_queue q,
nyeo.nyeo_block_control bc
where fer.clordid = q.sequence_number
and q.blockid = bc.blockid
and upper(bc.deskname) like '%ROSEN%'
	View 2 Replies
    View Related
  
    
	
    	
    	
        Dec 2, 2010
        I have a table "NEWS_COMMENT" like this:
Name      Type           
-------   -------------- 
ID  NUMBER(8)
USERID    NUMBER(8)
SORT_TEXT VARCHAR2(100) 
TEXT      VARCHAR2(1000) 
DATE      DATE
VALID     VARCHAR2(1)
CODNEW    NUMBER(10)   
The table has a normal index for the userid column.
There is a query that looks for the differents CODNEW for a USERID but allways the CODNEW has to be greater than 2248833
select codnew from news-comment  where userid=2914655 and valid='N' and codnew>2248833
I have created a new index for this kind of querys
create index coment_new_IDX on news_comment 
 (CASE  WHEN codnew >2248833 and valid='N' THEN userid ELSE NULL END )
but oracle doesn't use it. I have used a hint to force it but doesn't run. 
	View 9 Replies
    View Related
  
    
	
    	
    	
        Apr 7, 2011
        Here, let me explain:
I have create a table with 8 million records and 2 different indexes using 2 different columns (columns name NUM1 & NUM2) on that table. First indexed column (NUM1) values have many different values (1,2,3... etc).
Second indexed column (NUM2) values have only 2 different values. 
7999999 records values is same("A") and remaining one record values is different("B").
Query1:
select * from tbl where num1=val
Query2: 
select * from tbl where num2='B'
I have compare explain plan both queries, but Query2 doesn't use predefined index. Why Oracle don't use my redefined index at column NUM2?
	View 5 Replies
    View Related
  
    
	
    	
    	
        Oct 11, 2009
        I m looking for any other way that i can code without using union all for my case.my data example is like this 
table1
--------
col1     col2     Segment1    Segment2    Segment3
-------------------------------------------------------------
A11       B11     John        Jhonny      Johnathan
A12       B12     Melisa      Amy         Abagial
I need to create view of above record as below:
table2
------
col1            col2               col3               col4
--------------------------------------------------------------
A11             B11                Segment1           John
A11             B11                Segment2           Jhonny
A11             B11                Segment3           Johnathan
A12             B12                Segment1           Melisa
A12             B12                Segment2           Amy
A12             B12                Segment3           Abagial
now my code is using UNION ALL to get output as in table2
select col1,col1,'Segment1' col3,Segment1 col4 from table1
union all
select col1,col1,'Segment2' col3,Segment2 from table1
union all
select col1,col1,'Segment3' col3,Segment3 from table1
But the problem is the performance is realy bad.Is there any way i can do this without using union all? The time that take to execute this is not exceptable. 
	View 4 Replies
    View Related
  
    
	
    	
    	
        Dec 30, 2010
        We have large tables 60-70 GB having 120 million records. We have to perform index rebuild frequently which takes significant time to complete and effects database performance too. how we can use index Coalesce? what are its benefits, coalesce results in performance gain?
	View 10 Replies
    View Related
  
    
	
    	
    	
        Mar 30, 2006
        we have oracle 8i/win nt. (Prod Server running 24 X7)
On doing a explain plan on long running queries. i realized a couple of columns (that were used in the WHERE condition, were not having any indexes.)
More importantly, here we do not have a Test environment.
I would like to know if i can go ahead and create indexes for those 2 columns by issuing
CREATE INDEX index_name on table_name(Column_name);
on our PDB.
Would this be of any impact on our PDB? Do i check anything more prior to building these indexes. or Do have i create them at a down time of PDB.
	View 4 Replies
    View Related
  
    
	
    	
    	
        Aug 5, 2010
        this statement is taking 1hr , can we reduce the timing?
CREATE TABLE DGT_ITEMEFFORTDATA (ENTERPRISEID, OWNERTYPE, OWNERID, SUPEROWNERTYPE, SUPEROWNERID, 
ITEMTYPE, ITEMID, STAGEID, USERID, DATEIDENTIFIED,
DATECLOSED, ACTIVITYCODEID, PHASEID, RELEASEID, MONTHID, 
QUARTERID, INITIALEFFORT, BASELINEDEFFORT,
ACTUALEFFORT, ITEMSTATUS, ALLOCATIONSTATUS, STAGESTATUS, 
OCCURANCETYPE, DSLPROJECTTYPE, METRICCALCRUNID,
[code].....
This is the explain plan of the above query
PLAN_TABLE_OUTPUT
--------------------------------------------------------------------------------
--------------------------------------------------------------------------------
| Id  | Operation          | Name                     | Rows  | Bytes | Cost (%C
--------------------------------------------------------------------------------
|   0 | SELECT STATEMENT   |                          |    11M|  4137M| 46149  (
|   1 |  UNION-ALL         |                          |       |       |
|   2 |   TABLE ACCESS FULL| DGT_ITEMEFFORTDATA_DAILY |  3455K|   428M| 14575
[code].....
This is the index details
1DGT_ITEMEFFORTDATA_DAILYHCLT_IDX_DGT_IFDITEMID4
2DGT_ITEMEFFORTDATA_DAILYHCLT_IDX_DGT_IFDITEMTYPE3
3DGT_ITEMEFFORTDATA_DAILYHCLT_IDX_DGT_IFDOWNERID2
4DGT_ITEMEFFORTDATA_DAILYHCLT_IDX_DGT_IFDOWNERTYPE1
There is no index on DGT_ITEMEFFORTDATA_TEMP table
[code].....
	View 27 Replies
    View Related
  
    
	
    	
    	
        Jun 28, 2011
        I have a huge table (about 60 gb) partition over range. The index on this table is global index created on 4 columns together. I have a query which is running very slowly. The explain plan is showing the use of this global index.Explain plan is not showing pstart and pend because the index is global. 
	View 6 Replies
    View Related
  
    
	
    	
    	
        Aug 10, 2010
        which one is better?
unloading 5 tables of same structure using a ETL tool then merging the data
using Union operator to unload 5 tables then do transformations in ETL tool
	View 4 Replies
    View Related
  
    
	
    	
    	
        Aug 9, 2013
        How to force an index if the table not using the index?
	View 10 Replies
    View Related
  
    
	
    	
    	
        Sep 30, 2010
        How the length of column width effects index performance?
For example if i had IOT table emp_iot with columns: 
(id   number,
job  varchar2(20),
time date,
plan number)
Table key consist of(id, job, time)
Column JOB has fixed list of distinct values ('ANALYST', 'NIGHT_WORKED', etc...).
What performance increase i could expect if in column "job" i would store not names but concrete numbers identifying job names.
For e.g.  i would store "1" instead 'ANALYST' and "2" instead 'NIGHT_WORKED'.
	View 24 Replies
    View Related
  
    
	
    	
    	
        Feb 21, 2013
        I have a query optimized as to it indexes and others runs immediately when the answer is few records in SQL Server such as Oracle, however when the result is large eg 20,000 records all data access times are very diferent. The query returns many fields (about 20) and some of them are of type Varchar 250 and some of 2000 I understand here may be the problem, but not is because for similar results (20,000 records) sql run in 2 seconds and Oracle but it responds little to have full data takes around 30 seconds. The problem is really in bringing information to all these fields since if the inquiry it also but only returning a numeric field is done in 2 seconds. Tests I've done them both through ODBC, in the Toad as in the own Oracle console on the server, so it is not problem Driver or flow of data through the network, I would like to think that this is some of the settings I think there is as much difference between Oracle and Sql. The databases are ORACLE 10 and SQL Server 2008.
	View 1 Replies
    View Related
  
    
	
    	
    	
        Oct 26, 2013
        I wish to run a SQL query and measure elapsed time, then compare the values to other Oracle DBs from other companies. That will give me a feeling if our DB performs well.For example in UNIX world, you can create a random 4GB file to measure throughput I/O and compare the values (for example 4MB/sec).
What's the simplest way to compare DB response time from forum members to our own DB? I don't need 100% accurate numbers.
	View 1 Replies
    View Related
  
    
	
    	
    	
        Dec 24, 2012
        The below query is taking high CPU almost 98% and longer time to execute.
SELECT ancestor, 
       Max(D.alarmstate)     ALARMSTATE, 
       Max(D.sialarmstate)   SIALARMSTATE, 
       Max(D.uncralarmstate) UNCRALARMSTATE, 
       Max(M.commstate)      COMMSTATE, 
       Max(M.nncommstate)    NNCOMMSTATE, 
       Max(M.servicestate)   SERVICESTATE, 
       Max(M.abnormal)       ABNORMAL, 
       CASE 
     [code]....
	View 15 Replies
    View Related
  
    
	
    	
    	
        Jun 6, 2013
        We have a DELETE statement when coming from application is not using index but when run from Toad or SQLplus as same user uses index. Explain plan also shows using index.I did a query on v$sql below is the output of the query( I have attached the same as a txt file). All the stats are up to date and confirmed from the developer the variable B1 is using the same datatype as column MAXMKY. 
SQL_TEXTSQL_ID DISK_READSOPTIMIZER_HASH_VALUE     
DELETE LOTA WHERE MAXMKY=:B1 2g2prrp3z56ah19,099,1891,846,735,884
DELETE LOTA WHERE MAXMKY=:B1 2g2prrp3z56ah0        1,846,735,884
OPTIMIZER_COST HASH_VALUEPLAN_HASH_VALUE MODULEPARSING_SCHEMA_NAME
[code].....
	View 9 Replies
    View Related
  
    
	
    	
    	
        Nov 6, 2010
        I am working on a query for a feedback response system which is going to be targeted at the common case when the user only want the most recent 10-20 rows in the feedback table.  My though is to create an index on the date column, do a sort in an inner query and rownum <= in an outer query.  This works as I expect when I am only querying the main table (lookup by index with a stop key), but when I start joining the main table to attribute tables I end up with a full table scan of the main table with the stop key applied after all the joins are completed, the index is nowhere to be found.
CREATE TABLE attr1_tbl(attr1_id NUMBER NOT NULL, attr1 VARCHAR2(10) NOT NULL,
    CONSTRAINT attr1_pk PRIMARY KEY (attr1_id));
CREATE TABLE attr2_tbl(attr2_id NUMBER NOT NULL, attr2 VARCHAR2(10) NOT NULL,
    CONSTRAINT attr2_pk PRIMARY KEY (attr2_id));
CREATE TABLE attr3_tbl(attr3_id NUMBER NOT NULL, attr3 VARCHAR2(10) NOT NULL,
    CONSTRAINT attr3_pk PRIMARY KEY (attr3_id));
[code]....
One thing I noticed was that when no data is selected from the attribute tables, even if they are joined in the query, the CBO throws them out of the plan and only accesses the main table.  With the foreign keys this makes sense and really just disqualified my first thought that maybe I was missing a foreign key or not null constraint somewhere.
I also added the cardinality hint to overcome the chance that in my test case there was so little data that index access is not worth it.
	View 15 Replies
    View Related
  
    
	
    	
    	
        Mar 30, 2013
        I am going through this scenario:
* 35 | ID                             TABLE ACCESS BY INDEX ROW | S_ORG_EXT        |  3064K|  2472M|       |     1   (0)| 00:00:01 |
|  36 |                                INDEX FULL SCAN          | S_ORG_EXT_U1     |    14 |       |       |     1   (0)| 00:00:01 |
Predicate Information (identified by operation id):
---------------------------------------------------
35 - filter("T2"."ACCNT_FLG"<>'N' AND ("T2"."INT_ORG_FLG"<>'Y' OR "T2"."PRTNR_FLG"<>'N'))
This unselective index scan on step 36 of the explain is returning 14 rows but optimizer is selecting 3064 K rows from the table .
I tried creating combined index on all 3 columns mentioned in the  predicates for 35th step , but that is not utilized .
how to index this whole expression ::--
(ACCNT_FLG<>'N' AND (INT_ORG_FLG<>'Y' OR PRTNR_FLG<>'N'))
Something like CREATE INDEX XYZ on table((ACCNT_FLG<>'N' AND (INT_ORG_FLG<>'Y' OR PRTNR_FLG<>'N')) compute statistics ;
	View 3 Replies
    View Related
  
    
	
    	
    	
        Aug 9, 2010
        is there any way to reduce the index creation time.
in my case one index creation took 5 minute and there are 5 indexes , so it took 25 minutes.
	View 7 Replies
    View Related
  
    
	
    	
    	
        Jan 18, 2012
        I have the following problem. When I used in the IN-Statement fixed values e.q. 197321,197322,197323 ..., the index i_tab2_index works fine (index range scan).
But when I used in the IN-Statement an Sub-Select, the index i_tab2_index doesn't work (fast full scan)!My scale indices and used Selects:
CREATE INDEX i_tab1_index ON tab1 ( datum, flag_inst );
CREATE INDEX i_tab2_index ON tab2 ( tab2Idx, kontro );
SELECT count(epidx) as rowAnz
FROM tab2
WHERE tab2Idx IN ( SELECT tab1IDX FROM tab1
                   WHERE datum BETWEEN '20120117' AND '20120117'
                   AND flag_inst = '1' )
  AND kontro = '9876521'
[code]...
	View 12 Replies
    View Related
  
    
	
    	
    	
        Aug 26, 2010
        get all the unused index in the system , if i put this query in batch job and execute it every night upto one months and store its data in a table and after one months i can get all the used indexes and left would be our unused indexes.
select
  distinct  p.object_name c1
   from
   dba_hist_sql_plan p,
   dba_hist_sqlstat s
[Code]....
	View 23 Replies
    View Related