Index with NVL [message #483222] |
Fri, 19 November 2010 05:07 data:image/s3,"s3://crabby-images/3bcce/3bcce7084f96de28f8958fb8ba64988a13b0e75a" alt="Go to next message Go to next message" |
ss1_3
Messages: 4 Registered: December 2009
|
Junior Member |
|
|
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?
Thanks
|
|
|
|
Re: Index with NVL [message #483244 is a reply to message #483241] |
Fri, 19 November 2010 08:00 data:image/s3,"s3://crabby-images/5d024/5d02489f93cb86dd1a658de391c37413cb5e3f44" alt="Go to previous message Go to previous message" |
data:image/s3,"s3://crabby-images/7dccb/7dccb0215d12eec7aff82634bff49c1f5d959d76" alt="" |
Michel Cadot
Messages: 68737 Registered: March 2007 Location: Saint-Maur, France, https...
|
Senior Member Account Moderator |
|
|
Quote:I have tried creating index on
nvl(a.c2,'31-dec-9999')
But the CBO won't use it.
First, because '31-dec-9999' is not a date but a string.
Quote:Anyway to create index on this col so that full table scan can be avoided?
Why do you think FTS is bad?
Regards
Michel
|
|
|