inner join on range criteria: unable to use index?
Hello,
Even after searching for a while I'm having trouble understanding why this query is not faster:
select * from s inner join r on r.tstart >= s.chrstart and r.tend <= s.chrstop and r.tname=s.chr and r.strand=s.chrstrand;
tstart/tend/chrstart/chrstop are all bigint, and of the columns involved in the join, they are the most selective.
I would expect mysql to scan the smaller table, and then take advantage of a multi column index on the larger table on (start, stop, chr, strand), which is in order from most to least selective.
But mysql won't use that index. Why not?
Subject
Views
Written By
Posted
inner join on range criteria: unable to use index?
10421
August 11, 2008 04:34PM
3696
August 11, 2008 05:56PM
3755
August 11, 2008 06:04PM
3570
August 12, 2008 01:38AM
3242
August 12, 2008 09:30AM
3187
August 12, 2008 07:11PM
3709
August 12, 2008 12:52PM
3065
September 26, 2008 11:38PM
Sorry, you can't reply to this topic. It has been closed.
Content reproduced on this site is the property of the respective copyright holders.
It is not reviewed in advance by Oracle and does not necessarily represent the opinion
of Oracle or any other party.