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

Frage Entwicklung Datenbanken

MySQL Abfrage schlechte Performance

Mitglied: TorstenE

TorstenE (Level 1) - Jetzt verbinden

03.02.2014 um 17:37 Uhr, 1786 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
Benchmarks
Sehr schlechte SSD Performance
gelöst Frage von HenereBenchmarks9 Kommentare

Hallo zusammen, Hardware: ASUS Z10PE 16-WS Xeon 2620 v3 64 GB Reg ECC Ram Samsung 950pro SSD NVMe Im ...

RedHat, CentOS, Fedora
Schlechte RAID Performance
gelöst Frage von plex88RedHat, CentOS, Fedora9 Kommentare

Hallo Zusammen, ich habe für die Arbeit einen kleinen Backupserver gebastelt dieser besteht aus: Intel Core Quad Q8200 2GB ...

Netzwerkmanagement
Schlechte Performance im Heimnetz - Optimierungsmöglichkeiten
Frage von Matthias182Netzwerkmanagement39 Kommentare

Hallo zusammen, ich suche aktuell mal wieder nach etwas Unterstützung, um mein Heimnetz zu optimieren. Der Grund ist, dass ...

Virtualisierung
Hyper-V und Datenbanken - schlechte Performance
Frage von DerWoWussteVirtualisierung21 Kommentare

Moin Kollegen. Vor Beteiligung bitte alles genau lesen: Ich stelle gerade bei Performancetests fest, dass Hyper-V (2012R2 und Win10-Hyper-V) ...

Neue Wissensbeiträge
Tipps & Tricks

Solutio Charly Updater Fehlermeldung: Das Abgleichen der Dateien in -Pfad- mit dem Datenobject ist fehlgeschlagen

Tipp von StefanKittel vor 15 StundenTipps & Tricks

Hallo, hier einmal als Tipp für alle unter Euch die mit der Zahnarztabrechnungssoftware Charly von Solutio zu tun haben. ...

Sicherheit

Meltdown und Spectre: Wir brauchen eine "Abwrackprämie", die die CPU-Hersteller bezahlen

Information von Frank vor 15 StundenSicherheit10 Kommentare

Zum aktuellen Thema Meltdown und Spectre: Ich wünsche mir von den CPU-Herstellern wie Intel, AMD oder ARM eine Art ...

Sicherheit

Meltdown und Spectre: Realitätscheck

Information von Frank vor 16 StundenSicherheit9 Kommentare

Die unangenehme Realität Der Prozessorfehler mit seinen Varianten Meltdown und Spectre ist seit Juni 2017 bekannt. Trotzdem sind immer ...

Sicherheit

Meltdown und Spectre: Die machen uns alle was vor

Information von Frank vor 16 StundenSicherheit12 Kommentare

Aktuell sieht es in den Medien so aus, als hätten die Hersteller wie Intel, Microsoft und Co den aktuellen ...

Heiß diskutierte Inhalte
Windows 10
Netbook erkennt Soundkarte nicht - keinerlei Info zum Hersteller und Modell vom Netbook und Hardware bekannt
Frage von 92943Windows 1031 Kommentare

Guten Tag, meine Schwester reist in einigen Wochen für ein paar Monate ins Ausland und hat sich dafür ein ...

Batch & Shell
Anmeldevorgang für Informatikraum (Schule) unter Windows
gelöst Frage von IngenieursBatch & Shell29 Kommentare

Hey zusammen, ich werde in naher Zukunft den Informatik Raum meiner jetzigen Schule von dem aktuellen Betreiber übernehmen (Vertrag ...

Netzwerkgrundlagen
Welches Modem für VDSL 50000 der T-Com
gelöst Frage von Windows10GegnerNetzwerkgrundlagen21 Kommentare

Hallo, ein Kollege von mir will sich VDSL50000 von der T-Com holen, um daran einen Server zu betreiben. Ich ...

Batch & Shell
AD-Abfrage in Batchdatei und Ergebnis als Variable verarbeiten
gelöst Frage von Winfried-HHBatch & Shell19 Kommentare

Hallo in die Runde! Ich habe eine Ergänzungsfrage zu einem alten Thread von mir. Ausgangslage ist die Batchdatei, die ...