Możliwe, że mogłoby to być szybsze, ponieważ warunek LIKE może być oceniany szybciej niż wyrażenie regularne, więc jeśli większość wierszy nie przejdzie testu, może to być szybsze. Jednak będzie wolniejsze, jeśli większość wierszy się powiedzie, ponieważ dwa testy muszą zostać uruchomione dla udanych wierszy, a nie tylko jednego. Zależy to również od tego, które wyrażenie optymalizator wybierze do uruchomienia jako pierwsze.
Jeszcze większe przyspieszenie można zaobserwować, jeśli masz coś takiego:
SELECT * FROM (
SELECT * FROM lineage_string
WHERE lineage LIKE '179%'
) WHERE lineage regexp '^179(/|$)'
Teraz indeks może być użyty do znalezienia prawdopodobnych wierszy, ponieważ LIKE '179%' to sargable . Wiele wierszy w ogóle nie musi być sprawdzanych.
Jak zawsze najlepszym sposobem, aby się upewnić, jest zmierzenie go samemu na rzeczywistych danych.