Top-Themen

Aktuelle Themen (A bis Z)

Administrator.de FeedbackApache ServerAppleAssemblerAudioAusbildungAuslandBackupBasicBatch & ShellBenchmarksBibliotheken & ToolkitsBlogsCloud-DiensteClusterCMSCPU, RAM, MainboardsCSSC und C++DatenbankenDatenschutzDebianDigitiales FernsehenDNSDrucker und ScannerDSL, VDSLE-BooksE-BusinessE-MailEntwicklungErkennung und -AbwehrExchange ServerFestplatten, SSD, RaidFirewallFlatratesGoogle AndroidGrafikGrafikkarten & MonitoreGroupwareHardwareHosting & HousingHTMLHumor (lol)Hyper-VIconsIDE & EditorenInformationsdiensteInstallationInstant MessagingInternetInternet DomäneniOSISDN & AnaloganschlüsseiTunesJavaJavaScriptKiXtartKVMLAN, WAN, WirelessLinuxLinux DesktopLinux NetzwerkLinux ToolsLinux UserverwaltungLizenzierungMac OS XMicrosoftMicrosoft OfficeMikroTik RouterOSMonitoringMultimediaMultimedia & ZubehörNetzwerkeNetzwerkgrundlagenNetzwerkmanagementNetzwerkprotokolleNotebook & ZubehörNovell NetwareOff TopicOpenOffice, LibreOfficeOutlook & MailPapierkorbPascal und DelphiPeripheriegerätePerlPHPPythonRechtliche FragenRedHat, CentOS, FedoraRouter & RoutingSambaSAN, NAS, DASSchriftartenSchulung & TrainingSEOServerServer-HardwareSicherheitSicherheits-ToolsSicherheitsgrundlagenSolarisSonstige SystemeSoziale NetzwerkeSpeicherkartenStudentenjobs & PraktikumSuche ProjektpartnerSuseSwitche und HubsTipps & TricksTK-Netze & GeräteUbuntuUMTS, EDGE & GPRSUtilitiesVB for ApplicationsVerschlüsselung & ZertifikateVideo & StreamingViren und TrojanerVirtualisierungVisual StudioVmwareVoice over IPWebbrowserWebentwicklungWeiterbildungWindows 7Windows 8Windows 10Windows InstallationWindows MobileWindows NetzwerkWindows ServerWindows SystemdateienWindows ToolsWindows UpdateWindows UserverwaltungWindows VistaWindows XPXenserverXMLZusammenarbeit

MySQL Abfrage schlechte Performance

Mitglied: TorstenE

TorstenE (Level 1) - Jetzt verbinden

03.02.2014 um 17:37 Uhr, 1919 Aufrufe, 7 Kommentare

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.

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
Mitglied: AndiEoh
05.02.2014 um 12:43 Uhr
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
Bitte warten ..
Mitglied: Biber
05.02.2014, aktualisiert um 15:42 Uhr
Moin TorstenE,

ergänzend dazu:
Wenn du ohnehin keinen Index nutzen kannst, wird das unten etwas weniger langsam sein.

01.
SELECT DISTINCT artikel.* FROM artikel 
02.
LEFT JOIN tabelle2 ON tabelle2.artikel_id = artikel.id 
03.
LEFT JOIN tabelle3 ON tabelle3.artikel_id = artikel.id 
04.

05.
 WHERE artikel.name || coalesce(tabelle2.text, '') || coalesce(tabelle3.text, '') LIKE '%Suchbegriff%' 
Grüße
Biber
Bitte warten ..
Mitglied: TorstenE
05.02.2014 um 15:59 Uhr
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
Bitte warten ..
Mitglied: WinCobold
05.02.2014 um 16:02 Uhr
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
Bitte warten ..
Mitglied: TorstenE
05.02.2014 um 16:07 Uhr
so schnell platzt eine Idee
Bitte warten ..
Mitglied: Biber
05.02.2014, aktualisiert um 16:10 Uhr
Moin WinCobold,

na, dieses kleine Detail können wir abstellen:
01.
SELECT DISTINCT artikel.* FROM artikel 
02.
LEFT JOIN tabelle2 ON tabelle2.artikel_id = artikel.id 
03.
LEFT JOIN tabelle3 ON tabelle3.artikel_id = artikel.id 
04.

05.
 WHERE artikel.name || '#' 
06.
             || coalesce(tabelle2.text, '') || '#'  
07.
             || coalesce(tabelle3.text, '')
08.
             LIKE '%Suchbegriff%' 
Aber danke für den richtigen Einwand.

Grüße
Biber
Bitte warten ..
Mitglied: AndiEoh
05.02.2014 um 18:34 Uhr
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

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.
Bitte warten ..
Ähnliche Inhalte
Windows Server
DNS Performance schlecht
Frage von HenereWindows Server14 Kommentare

Servus zusammen, ich habe gerade auf 2 Servern teils extrem verzögerte Antworten auf DNS-Requests für externe hosts. Es betrifft ...

Debian
MySQL Workbench mysql old password
Frage von Fenris14Debian3 Kommentare

Hallo, ich habe hier auf einem Linux Mint den SQL-Client "MySQL Workbench" installiert. Beim anlegen einer neuen Verbindung und ...

Datenbanken

MYSQL Replikation mysql: unknown variable

Frage von Bender999Datenbanken2 Kommentare

Hallo, wollte eine Master Slave Replikation einrichten. Auf der Master Seite steht in der Ini: server-id=1 log-bin=mysql-bin starte ich ...

Server-Hardware

Server runterfahren gut, bzw. schlecht für Festplatten?

Frage von 114068Server-Hardware31 Kommentare

Hallo, wir haben einige betagte Server bei uns rumstehen, die schon jahrelang brav liefen. Jetzt müssen die allerdings in ...

Neue Wissensbeiträge
Windows Server
Windows Backup - FilterManager Event 3
Tipp von NixVerstehen vor 6 StundenWindows Server

Hallo zusammen, ich bin kein gelernter ITler und auch beruflich nicht in dem Feld tätig. Wir setzen in unserem ...

Windows 10

Windows 10 - Programme laufen schneller, wenn Sie mit Administratorrechten ausgeführt werden

Erfahrungsbericht von 1Werner1 vor 1 TagWindows 1011 Kommentare

Moin, das wollte ich erst nicht glauben, aber es ist so. Wenn Ihr ein Programm mit Administratorrechten unter Windows ...

Sicherheits-Tools
Putty hat heftige Bugs korrigiert!
Information von Lochkartenstanzer vor 2 TagenSicherheits-Tools8 Kommentare

Moin, Wie man aus herauslesen kann, sind in den Versionen vor 0.71 gravierende Bugs, die es angeraten erscheinen lassen, ...

Off Topic
Sachen die die Welt nicht braucht - Platz 1
Tipp von brammer vor 5 TagenOff Topic21 Kommentare

Hallo, ich habs als Tipp angelegt als Erfahrungsbericht nein Danke brammer

Heiß diskutierte Inhalte
Hardware
Telefonanlagen - Welche gibt es
Frage von Xaero1982Hardware34 Kommentare

Nabend Zusammen, ich suche eine neue TK Anlage und mein Auftraggeber will jetzt was völlig neues - State of ...

Outlook & Mail
Office 365 mit Email-Profil installieren
Frage von Carat2121Outlook & Mail18 Kommentare

Hallo, kurz zu meiner Person: Vor ungefahr 10 Jahren habe ich eine Umschuldung zum Fachinformatiker für Systemintegration gemacht aber ...

LAN, WAN, Wireless
Intel(R) PRO Wireless 3945ABG
gelöst Frage von Leon509LAN, WAN, Wireless15 Kommentare

Hallo, habe ein Laptop Fujitsu (Intel, 4GB, 2GHz, Windos10, Intel(R) PRO/Wireless 3945ABG ) ein O2 DSL Anschluss Home50. Leider ...

Microsoft Office
Excel Such- und Vergleichsfunktion
gelöst Frage von oesi1989Microsoft Office15 Kommentare

Hallo zusammen, ich habe 2 Tabellen mit Name, Vorname und Arbeitgeber. 1. Tabelle Name Vorname Geb-Datum Arbeitgeber Straße Ort ...