możesz wypróbować zapytanie Top-N, aby znaleźć pierwszego kandydata, a następnie zastosować go tylko do rzeczywistego wzorca:
select 1
from (select c1
from junk
where c1 <= 'fxg87698x84'
order by c1 desc limit 1) tmp
where 'fxg87698x84' like concat(c1, '%');
górne zapytanie powinno używać zwykłego indeksu na c1.
EDYTUJ :Wyjaśniłem to bardziej szczegółowo na moim blogu:http://blog.fatalmind.com/2010/09/29/finding-the-best-match-with-a-top-n-query/