PL/SQL :: Number Range Query Causes Repeated Scan By Index
			Oct 16, 2012
				I have a query that seems to repeatedly call an index scan on a table for reasons I'm not sure about. Why it would be doing the index scan on totaldwellingarea in the dimensions table (DIMEN_PID_TDWELLAREA) repeatedly? This only seems to happen when I put on the range clause d.totaldwellingarea between scr.lowvalue and scr.highvalue.
I am using Oracle version 9.2.0.3.
select d.propertyid,d.totaldwellingarea, e.size_,  scr.size_
from  eqid e, dimensions d,  brt_eval.size_code_ranges scr
where e.style not in ('1','A','G','L') and e.size_  = '0'
and d.propertyid = e.propertyid and e.style = scr.style and d.totaldwellingarea between scr.lowvalue and  scr.highvalue;
CREATE
  TABLE "BRT_ADMIN"."EQID"
  (
    "PROPERTYID"   VARCHAR2(20 BYTE) NOT NULL ENABLE,
    "EQID"         CHAR(10 BYTE),
    "ZONE_"        CHAR(1 BYTE),
    "AREA"         CHAR(1 BYTE),
[code].....
	
	View 3 Replies
  
    
		
ADVERTISEMENT
    	
    	
        Jul 15, 2011
        How can i force a sql use index range scan?
	View 10 Replies
    View Related
  
    
	
    	
    	
        Oct 18, 2011
        In the link below [URL] Thomas kyte has said, use the CBO and select /*+ FIRST_ROWS */ primary_key from table where rownum = 1; it'll read the index and stop at the first row. very fast on a big empty table (as the index is  small and empty).
very fast on a big full table as the index is just read to find the first leaf node and then "stop".
It gives faster result if the primary key is used. But what if we have a table with around 1000 million rows and for the predicates there is a index range scan on the table. 
What if we have a table say big_table (10000000000 rows) and the sql is something like
select /*+ first_rows */ 1 /* id, attribute_id*/
 from big_table
 where attribute_name ='Gross Premium'
and value ='10000'
and version_date is null
and rownum=1; --it's taking around 3 min
We observed that in such case there will be a range index scan for the index on the predicates. For a particular id there may be different values for attribute 'Gross Premium' and may have multiple versions.
How I would tune such a query where the purpose is to check if at least 1 records exists in the table for the input?
	View 4 Replies
    View Related
  
    
	
    	
    	
        Oct 5, 2013
        Let's consider such table that all rows fit into single block:
SQL> create table test as select rownum id, '$'||rownum name from dual connect by level <= 530;
Table created.
SQL> create index i_test on test(id);
Index created.
SQL>
SQL> begin
[code].....
why does approach with full scan take longer even if table occupies only one data block? PS. 11gR2
	View 8 Replies
    View Related
  
    
	
    	
    	
        Dec 19, 2011
        I want to make full table scan of my query so that I can execute it using parallel option & the query will get completed in few mins. Even though I used this hint "/*+ parallel(t2,4) full(t2) */, the query is executing with 8 parallel processes but it is going for "Rowid Range Scan" and it is taking more time to complete. How to make this query to go for full table scan instead of "Rowid Range Scan" so that this query can be tuned.
SELECT   /*+ parallel(t2,4) full(t2)*/ID, COUNT (1) FROM acnt_transact t2 GROUP BY ID;
	View 9 Replies
    View Related
  
    
	
    	
    	
        Mar 11, 2010
        diff of unique scan and range scan?
	View 1 Replies
    View Related
  
    
	
    	
    	
        Apr 27, 2013
        create table call(id number(10) primary key,mobile_no number(10), other_no number(10), call_type varchar2(10),call_date_time date, duration number(10));
insert into call values(1,9818764535,9899875643,'IN','24-APR-13 02:10:43',10);
insert into call values(1,9818764535,9898324234,'IN','24-APR-13 05:06:78',10);
insert into call values(1,9818764535,9215468734,'IN','24-APR-13 15:06:78',10);
insert into call values(1,9818764535,9899875643,'OUT','25-APR-13 01:06:78',10);
insert into call values(1,9899875643,9899875643,,'OUT','25-APR-13 22:06:78',10);
Query : need to find first and last call of '9818764535' mobile number and of call_date between '24-apr-13' and '25-apr-13';
Result : 
date ,mobile_no , other_no, call_type, duration
24/apr/13 , 9818764535,9899875643,'IN',10
24/apr/13 ,9818764535,9215468734,'IN',10
[Code]....
	View 5 Replies
    View Related
  
    
	
    	
    	
        Aug 29, 2011
        I am adding condition in color to my existing query but my query taking too long time after that. This condition calculates last 3 month end dates from given COB (20110516).
SUMMARY is my summarized table and COB is my reference table
Without adding condition in query it gives 
INDEX (RANGE SCAN)--PK_SUMMARY(INDEX(UNIQUE))
After adding condition in query it gives
INDEX(FAST FULL SCAN)--PK_SUMMARY(INDEX(UNIQUE))
 how can i keep RANGE SCAN even after adding my new conditions?
SELECT
distinct
  COB.COB_ID_C,
  SUMMARY.SUMM_COB_ID_C
FROM
  
[code]...
	View 4 Replies
    View Related
  
    
	
    	
    	
        Aug 15, 2012
        i nee a function which accepts 4 digit number and in four digit number the number should not be repeated. i want all the number in the output.
ex:1234
2367
1262(is not valid)
	View 20 Replies
    View Related
  
    
	
    	
    	
        Nov 17, 2012
        if i have local index, does query which uses this index always have to scan all partitions?
For example, I have hash-partitioned table on column A. There is local index on column B. I am querying:
select * from my_table where A='ABC' and B>123.
I know that records with A='ABC' are in 2nd partition. Does only 2nd partition of local index will be scanned or all of them must be scanned?
	View 1 Replies
    View Related
  
    
	
    	
    	
        Dec 13, 2012
        I have table with the values as below.
C1C2C3C4
NAMEJOHN10ABC
NAMESMITH30DEF
NAMEROBERT60XYZ
I dont want to print the repeated value(NAME) of C1 multiple times as below.
C1C2C3C4
NAMEJOHN10ABC
SMITH30DEF
ROBERT60XYZ
I could do it using the below query using union with the rownum.
select * from (
select rownum rn, c1,c2,c3,c4 from table_new 
) where rn =1
union
select * from (
select rownum rn, decode(c1,null,null),c2,c3,c4 from table_new 
) where rn between 2 and 3
Is there any other way of displaying using a single sql query.
	View 17 Replies
    View Related
  
    
	
    	
    	
        Jun 14, 2012
        Is there any hint to force "Index Unique Scan" over "Index Range Scan".
My query is generating different plans with the above two, and very slow when it uses "Index Range Scan".
	View 19 Replies
    View Related
  
    
	
    	
    	
        Apr 23, 2012
        I am rebuilding some UNUSABLE local index partitions on Oracle 8.1.7.4.0 (64bit) database . The platform is a HPUX machine.
The DDL of the partition table/indexes:
=========================
CREATE TABLE   TESTME
(  INST_NO CHAR(3) NOT NULL, 
   ACCT_NO CHAR(16) NOT NULL, 
   REC_NO CHAR(9) NOT NULL, 
   TRAN_TYPE CHAR(2) DEFAULT ' ', 
   STAT CHAR(2) DEFAULT ' ', 
   [code]...
	View 2 Replies
    View Related
  
    
	
    	
    	
        May 12, 2011
        I have created an  non unique index lk_fein  on lookup_fein( code,map_id,trash). When I check the explain plan it does a full table scan on lookup_fein. if I force it to use index by  it does and the cost also decreases.
SQL> SELECT WORK_FEIN,
  2    NON_FEIN       ,
  3    FI_FEIN        ,
  4    MFEIN          ,
  5    TOTAL_FEIN     ,
[code]...
	View 1 Replies
    View Related
  
    
	
    	
    	
        Oct 29, 2013
        I am creating a table where ID is an integer and the where clause will always be in range(for e.g between 200 and 400).
for best performance which index can i create on table such that query runs faster ?(a)clustered(b)non-clustered(c)unique(d)both clustered and non clustered
	View 0 Replies
    View Related
  
    
	
    	
    	
        Apr 9, 2013
        We are using oracle 11.2.0.3.0 with 3 node rac. Earlier 3 scan vip and 3scan listener running on each node.But we found recently node1 running using 2vip and 2scanlistener and in node2 1vip and 1scanlisteners were running.but no longer running scan vip or scan listener in node 3. If i decided to reloacate the scan vip/Scan_listener to node3 from ndoe 1 using below command,does it cause any impact on my transcation?
$ srvctl relocate scan -i 2 -n node03
$ srvctl relocate scan_LISTENER -i 2 -n node03
find the below details
$ bash
bash-4.2$ srvctl status scan
SCAN VIP scan1 is enabled
[Code]....
	View 12 Replies
    View Related
  
    
	
    	
    	
        Aug 18, 2012
        I�m Using Oracle 11.I have a table with 16 million rows and an index (let's call it the employee table with an index on department). I need to select all the employees whose departments are located in the uk. I achieve this by selecting all the department numbers from departments where location = 'UK' in a sub select then plug this into the main query as follows:
SELECT    *
    FROM   employees
  WHERE   department IN (SELECT department from departments where location = 'UK');
It takes ages, 25 seconds or more, the explain plan shows its doing a full table scan on emplyees. I need it to use the index. The sub query is instant and returns only 5 rows. If I explicitly put the 5 numbers in the IN clause the query uses the index and executes in 0.04 seconds. See below:
SELECT    *
    FROM   employees
  WHERE   department IN (1,2,3,4,5);
I need it to use the subquery once and then use the index on the main table.
	View 2 Replies
    View Related
  
    
	
    	
    	
        Dec 19, 2012
        I have, it would appear, successfully installed APEX 4.2 & APEX Listener 2.0 EA (in WebLogic). APEX works fine and it's reverse proxied using mod_weblogic through the OHS. I have configured APEX Printing to be via the APEX Listener.
However, creating a simple report, enabling printing, running the report (e.g. PDF or Word) produces the following few-byte content (only) inside the actual PDF file (obviously not in PDF format):
String index out of range: -1
Furthermore, it throws the exception below on the WebLogic console.
Any experience with the APEX Listener - and if so managed to rectify it?
SEVERE: String index out of range: -1
java.lang.StringIndexOutOfBoundsException: String index out of range: -1
at java.lang.String.substring(String.java:1931)
at oracle.dbtools.apex.hooks.postProcess.FOP2PDF.requestTOPDF(FOP2PDF.java:82)
at oracle.dbtools.apex.hooks.postProcess.FOP2PDF.postProcess(FOP2PDF.java:36)
[Code]...
	View 2 Replies
    View Related
  
    
	
    	
    	
        Oct 24, 2011
        I created table Rang pertitionned, and List subpartitionned. My table is Interval partitionning. My subpartition is template based as is :
PARTITION BY RANGE ( DINFOIDENTITE ) 
INTERVAL ( (NUMTOYMINTERVAL(1,'MONTH')) ) 
SUBPARTITION BY LIST ( AVANT_DERNIER_MATCLE )
[Code]....
i would have the same repartition with 10 differents tablespaces, one for each subpartition.
I search on Oracle documentation this morning, but the only thing i've found is that this option is possible with the STORE IN clause, but only for HASH partitionning.
Is there a way to specify STORAGE clause with a template for my indexes ?
	View 4 Replies
    View Related
  
    
	
    	
    	
        Jul 11, 2013
        Below query is degrading the performance of database. As we know that, without where clause, query do full table scan.Now, it is written to generate the sequence no.
SQL> explain plan for
  2  SELECT NVL(MAX(P.NUM_SERIAL_NO), 0) + 1 FROM CNFGTR_IRDA_ENVELOPE_DTLS P
  3  /
Explained.
SQL> select * from table(dbms_xplan.display());
PLAN_TABLE_OUTPUT
----------------------------------------------------------------------------------------------------
Plan hash value: 3345343365
------------------------------------------------------------------------------------------------
| Id  | Operation          | Name                      | Rows  | Bytes | Cost (%CPU)| Time     |
------------------------------------------------------------------------------------------------
[code].....
Index is not created on the column.
	View 6 Replies
    View Related
  
    
	
    	
    	
        Aug 31, 2010
        My understanding of DB_FILE_MULTIBLOCK_READ_COUNT parameter is that it affects only Full Table Scans and Fast Full Index Scans - all other disk retrieval is single block.If so, then maybe I'm reading this trace incorrectly:
select /*+ first_rows */ pk
from test_join_tgt
where pk >= 0
and rownum > 1
call     count       cpu    elapsed       disk      query    current        rows
------- ------  -------- ---------- ---------- ---------- ----------  ----------
Parse        1      0.01       0.00          0          0          0           0
Execute      1      0.00       0.00          0          0          0           0
Fetch        1     21.48      27.77      22368      22134          0           0
------- ------  -------- ---------- ---------- ---------- ----------  ----------
total        3     21.49      27.78      22368      22134          0           0
[code]...
What the heck is going on with the Multi-block reads in the Range Scan?
	View 3 Replies
    View Related
  
    
	
    	
    	
        Apr 21, 2011
         i have a requirement To partition a Table byRange partition with a Number column. but the issue is the range Must be in a Date datatype , 
For example
partition by range (date_key)
     ( PARTITION DEF VALUES LESS THAN ('01-SEP-10'))
the date_key column has values of date in  number format. like "20101014"
	View 2 Replies
    View Related
  
    
	
    	
    	
        Jul 12, 2012
        I have a table with two columns Column1 and column2 
Like such
create table testTable (column1 number(15), column2 number(15));
 
 insert into testTable values (1,5);I need to find the numbers between column 1 and column 2 including the column 1's number and column's 2 number.
so my answer set should be
 1,2,3,4,5
	View 4 Replies
    View Related
  
    
	
    	
    	
        Feb 3, 2012
        when i am  Executing the following statement
SELECT DISTINCT EXPOSURE_REF FROM KBNAS.VW_EXPOSUREDETS_FOR_CCYREVAL
WHERE EXPOSURE_CURRENCY='THB' AND BASE_TXN_CCY='USD' AND BRANCH_CODE='7000'
AND (REVAL_STATUS='O') AND CONV_RATE<>'62' AND (EXPOSURE_AMOUNT<>0)
UNION
SELECT DISTINCT ED.EXPOSURE_REF FROM KBNAS.EXPOSURE_DETAILS ED,
[code].....
I have attached DDL for table EXPOSURE_DETAIL(PARTITION),LEDGERCARD,LEDGERCARDDETAILS, DDL for INDEX on those tables and DDL for Views..
Issue: we have created the Indexes but when we check the explain plain .. full table scan is going on..I have attached the explain plan ..
	View 11 Replies
    View Related
  
    
	
    	
    	
        Jul 14, 2011
        I have following requirement. Let say i have to generate a range based on "start number" and "end number" dynamically.Some kind of hash buckets.
e.g Start Number : 1 and End Number : 1001. 
Also i want to divide that range based on some dynamic value like for above example 10 ranges of 100 each. and both 1 and 1001 should be included only once and the next row start number cannot be same as previous row end number.
Means
 
Range 1 1 -101
Range 2 102-200
Range 3 201-300 
...
Range 10 901-1001
Is there any way of doing it automatically. I tried with Model clause. it works fine for even cases but for odd i have issues also when i take small start and end number i get an error.
SELECT case when ranges=1 then ranges else ranges+1 end Start_Id, ranges+round((1001-1)/10) End_Id
from
(
[Code].....
I want this to be generic for any values here 1 is Start Number 1001 is end number and 10 is the bucket. I need these parameters dynamic and want's the same kind of results for any values.
	View 22 Replies
    View Related
  
    
	
    	
    	
        Nov 15, 2013
        Database Version : DB : Oracle Database 11g Enterprise Edition Release 11.2.0.3.0 - 64bit ProductionOS : HP-UX nduhi18 B.11.31 U ia64 1022072414 unlimited-user licenseAPP : SAP - ERP I have to RANGE partition on UPDATED_ON  or PROFILE  either one table which is having below 
structure :   Name                Null?    Type
 -------------------- -------- -------------------------------- 
MANDT                NOT NULL VARCHAR2(9) MR_ID                NOT NULL VARCHAR2(60) PROFILE              NOT NULL VARCHAR2(54) REGISTER_ID          NOT NULL VARCHAR2(30) INTERVAL_DATE        NOT NULL VARCHAR2(24) AGGR_CONSUMPTION     NOT NULL NUMBER(21,6) MDM_VERS_NO          NOT NULL VARCHAR2(9) MDP_UPDATE_DATE      NOT NULL VARCHAR2(24) MDP_UPDATE_TIME      NOT NULL VARCHAR2(18) NMI_CONFIG           NOT NULL VARCHAR2(120) NMI_CONFIG_FLAG      NOT NULL VARCHAR2(3) MDM_DATA_STRM_ID     NOT NULL VARCHAR2(6) NSRD                 NOT NULL VARCHAR2
[Code]....
 As per my knowledge, RANGE is better suited for DATE or NUMBER. and INTERVAL partition is possible on DATE or NUMBEr . Column PROFILEIts is of VARCHAR2 datatype. I know still I can partition as Oracle internally convert varchar2 to number while inserting data. But INTERVAL is not possible.  How to RANGE partition on PROFILE ? Column CREATED_ON :It is of NUMBER with decimal
	View 0 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
  
    
	
    	
    	
        Jul 26, 2013
        I want output like given below. Using EMp table . if sal is <1000 means count of Emp's who are having lessthan 1000 like that.
Deptno       sal         sal          sal        sal
    <=1000       <=2000      <=3000     <= 5000
  10     2   4
  20     2.
	View 2 Replies
    View Related
  
    
	
    	
    	
        Dec 8, 2011
        I have a table partitioned by Range and subparitioned by hash.
i am issuing the following query .Bcos of security purposes i cannot post the full query.
Select <most of the columns>
FROM qosTesthr PARTITION(PARTITION_ON_2011_11_17)
WHERE starttime BETWEEN to_date('1111170000', 'yymmddHH24mi') AND    to_date('1111172359', 'yymmddHH24mi')
Explain plan is
--------------------------------------------------------------------------------------------------------------------------------------------- 
| Id  | Operation             | Name                   | Rows  | Bytes | Cost (%CPU)| Time     | Pstart| Pstop |    TQ  |IN-OUT| PQ Distrib 
---------------------------------------------------------------------------------------------------------------------------------------------                        
|   0 | SELECT STATEMENT      |                        |   826K|   171M|  2330   (4)| 00:00:28 |       |       |        |      |            |                                                                                                                                                                
|*  1 |  PX COORDINATOR       |                        |       |       |            |          |       |       |        |      |            |                                                                                                                                                                
|   2 |   PX SEND QC (RANDOM) | :TQ10000               |   826K|   171M|  2330   (4)| 00:00:28 |       |       |  Q1,00 | P->S | QC (RAND)  
[code]...
When  i use INDEX_SS hint in the query then only the partition scan is happening.
---------------------------------------------------------------------------------------------------------------------------------                                                    
| Id  | Operation                            | Name                     | Rows  | Bytes | Cost (%CPU)| Time     | Pstart| Pstop |                                                                                                                                                                            
---------------------------------------------------------------------------------------------------------------------------------                                                      
|   0 | SELECT STATEMENT                     |                          |   826K|   171M|   810K  (1)| 02:42:06 |       |       |                                                                                                                                                                            
|*  1 |  FILTER                              |                          |       |       |            |          |       |       |                                                                                                                                                                            
[code]...
Performance while using the index is very very slow.Is there any way without using the index and just the partition full scan can be forced by using some hint..
	View 1 Replies
    View Related
  
    
	
    	
    	
        Jun 30, 2010
        I have a table which contains two columns containing the range of some products. These range are alphanumeric and i want to calculate the count of this range by a query. .
test case: 
CREATE TABLE MARRIAGE_FILE_NAME
(
  START_SERIAL_NO  VARCHAR2(10 BYTE)            NOT NULL,
  END_SERIAL_NO    VARCHAR2(10 BYTE)            NOT NULL,
  CATCODE          VARCHAR2(10 BYTE)            NOT NULL,
 
[code]....
	View 2 Replies
    View Related