MySQL Abfrage schlechte Performance
Ich mache folgende Abfrage
Suche alle Artikel in welchem der "Suchbegriff" im Name des Artikels vorkommt oder
in 2 weitern Tabellen, jeweils in einem FULLTEXT Feld.
artikel ca. 6.000 Einträge
tabelle2 ca. 3.000 Einträge
tabelle3 ca. 12.000. Einträge
Die Suche geht bis zu 170 Sekunden obwohl auf dem "name" und den "text" Feldern jeweils auch ein Index ist.
Was ist an der Abfrage falsch ?
Torsten.E
Suche alle Artikel in welchem der "Suchbegriff" im Name des Artikels vorkommt oder
in 2 weitern Tabellen, jeweils in einem FULLTEXT Feld.
SELECT DISTINCT artikel.* FROM artikel
LEFT JOIN tabelle2 ON tabelle2.artikel_id = artikel.id
LEFT JOIN tabelle3 ON tabelle3.artikel_id = artikel.id
WHERE artikel.name LIKE "%Suchbegriff%"
OR tabelle2.text LIKE "%Suchbegriff%"
OR tabelle3.text LIKE "%Suchbegriff%"
artikel ca. 6.000 Einträge
tabelle2 ca. 3.000 Einträge
tabelle3 ca. 12.000. Einträge
Die Suche geht bis zu 170 Sekunden obwohl auf dem "name" und den "text" Feldern jeweils auch ein Index ist.
Was ist an der Abfrage falsch ?
Torsten.E
Bitte markiere auch die Kommentare, die zur Lösung des Beitrags beigetragen haben
Content-ID: 228566
Url: https://administrator.de/forum/mysql-abfrage-schlechte-performance-228566.html
Ausgedruckt am: 02.02.2025 um 05:02 Uhr
7 Kommentare
Neuester Kommentar
Hallo,
ich bin sicher kein SQL König aber meines Wissen nach kann der Index nicht verwendet werden wenn "LIKE" mit Wildcards am Anfang verwendet wird. Um das zu prüfen solltest du mal EXPLAIN bzw. DESCRIBE verwenden:
http://dev.mysql.com/doc/refman/5.1-olh/de/using-explain.html
Gruß
Andi
ich bin sicher kein SQL König aber meines Wissen nach kann der Index nicht verwendet werden wenn "LIKE" mit Wildcards am Anfang verwendet wird. Um das zu prüfen solltest du mal EXPLAIN bzw. DESCRIBE verwenden:
http://dev.mysql.com/doc/refman/5.1-olh/de/using-explain.html
Gruß
Andi
Moin TorstenE,
ergänzend dazu:
Wenn du ohnehin keinen Index nutzen kannst, wird das unten etwas weniger langsam sein.
Grüße
Biber
ergänzend dazu:
Wenn du ohnehin keinen Index nutzen kannst, wird das unten etwas weniger langsam sein.
SELECT DISTINCT artikel.* FROM artikel
LEFT JOIN tabelle2 ON tabelle2.artikel_id = artikel.id
LEFT JOIN tabelle3 ON tabelle3.artikel_id = artikel.id
WHERE artikel.name || coalesce(tabelle2.text, '') || coalesce(tabelle3.text, '') LIKE '%Suchbegriff%'
Grüße
Biber
Hallo Biber,
ich verbessere dich zwar nur ungern, weil ich deine Beiträge als sehr fundiert (und oft erfrischend zynisch) kenne, aber nach dem Aneinanderhängen der drei Spalten kann der LIKE mehr Treffer finden, weil dann ja auch das Ende von artikel.name zusammen mit dem Anfang von tabelle2.text usw. passen könnte.
Grüße vom WinCobold
ich verbessere dich zwar nur ungern, weil ich deine Beiträge als sehr fundiert (und oft erfrischend zynisch) kenne, aber nach dem Aneinanderhängen der drei Spalten kann der LIKE mehr Treffer finden, weil dann ja auch das Ende von artikel.name zusammen mit dem Anfang von tabelle2.text usw. passen könnte.
Grüße vom WinCobold
Moin WinCobold,
na, dieses kleine Detail können wir abstellen:
Aber danke für den richtigen Einwand.
Grüße
Biber
na, dieses kleine Detail können wir abstellen:
SELECT DISTINCT artikel.* FROM artikel
LEFT JOIN tabelle2 ON tabelle2.artikel_id = artikel.id
LEFT JOIN tabelle3 ON tabelle3.artikel_id = artikel.id
WHERE artikel.name || '#'
|| coalesce(tabelle2.text, '') || '#'
|| coalesce(tabelle3.text, '')
LIKE '%Suchbegriff%'
Aber danke für den richtigen Einwand.
Grüße
Biber
Zitat von @TorstenE:
Weshalb kann ich keinen Index nehmen ?
Bei MyISAM kann ich doch einen FULLTEXT Index nehmen, oder ?
Nur wenn ich auf INNODB umstelle geht es nicht
Aber die Abfrageart gefällt mir, versuch ich troztdem
Weshalb kann ich keinen Index nehmen ?
Bei MyISAM kann ich doch einen FULLTEXT Index nehmen, oder ?
Nur wenn ich auf INNODB umstelle geht es nicht
Aber die Abfrageart gefällt mir, versuch ich troztdem
Sieht für mich so aus als ob ein FULLTEXT Index nur bei speziellen Abfragen verwendet werden kann:
http://dev.mysql.com/doc/refman/5.1/de/fulltext-restrictions.html
Desweiteren bleibt meines Wissen nach die Beschränkung auf Suchen ohne Wildcard am Anfang. Mit Wildcard am Anfang kann das gesuchte Token beliebig lang werden und der eigentliche Suchtext beliebig spät im Wort auftreten, d.h. ein Index müsste über beliebige Teilbereiche der vorhandenen Wörter gebildet werden...
Aber eventuell weiß ja jemand was genaueres.