php.de

Zurück   php.de > Webentwicklung > Datenbanken

Datenbanken SQL und Co

Antwort
 
LinkBack Themen-Optionen Thema bewerten
Alt 05.01.2009, 13:40  
Neuer Benutzer
 
Registriert seit: 31.12.2008
Beiträge: 10
Thisi befindet sich auf einem aufstrebenden Ast
Standard SQL Abfrage ohne DESC langsam

Hallo zusammen,

ich habe ein Problem mit dieser Abfrage hier:

PHP-Code:
SELECT d.DealerCoded.DealerNamed.CitySUM(q.A3) AS 'Interviews'r.QCES
FROM tblDealerAdresses 
AS d
INNER JOIN tblQuestionairesS 
AS q
ON d
.DealerCode q.DealerCode
INNER JOIN tblResultsSalesPrint 
AS r
ON d
.DealerCode r.DealerCode
WHERE q
.RunNo BETWEEN 97 AND 108 AND r.RunNo 108
GROUP BY d
.DealerCoded.DealerNamed.Cityr.QCES
ORDER BY QCES DESC 
Die Abfrage funktioniert soweit gut. Die ganze Abfrage wird normalerweise Dynamisch zusammen gestellt und ein Parameter davon ist die Anzahl der Datensätze (TOP ....). Wenn im ORDER BY DESC steht ist es egal welche TOP-Anzahl ich ihm gebe, es ist immer schnell. Sobald ich aber ASC bei ORDER BY nehme kommen die Probleme. Wenn die ganze Ausgabe ohne TOP ist geht es auch super schnell. Es funktioniert genau bis TOP 49 und höherl, nehme ich aber TOP 48 und kleiner, benötigt die Abfrage ca. 14 Sekunden und mehr, bei TOP 1 dauert sie sogar 22 Sekunden. Insgesamt sind es 601 Datensätze.

Wie kann ich das nun verhindern. Ein Möglichkeit ist sicher eine TempTabelle zu erstellen aber diese Lösung finde ich nicht so gut. Auch habe ich an Index usw. gedacht nur die Abfrage funktioniert ja bis =>49.

Bin für jeden Tipp dankbar.
Thisi ist offline   Mit Zitat antworten
Sponsor Mitteilung
PHP Code Flüsterer

Registriert seit: 21.08.2005
Beiträge: 4682
PHP-Kenntnisse:
Fortgeschritten

Alt 05.01.2009, 14:31  
erc
Erfahrener Benutzer
 
Registriert seit: 02.01.2009
Beiträge: 730
PHP-Kenntnisse:
Fortgeschritten
erc wird schon bald berühmt werden
Standard

Den Query mit EXPLAIN ausführen (in der lagsamen und schnellen version) und die Ausgabe posten. (EXPLAIN SELECT ...)
erc ist offline   Mit Zitat antworten
Alt 05.01.2009, 14:35  
Neuer Benutzer
 
Registriert seit: 31.12.2008
Beiträge: 10
Thisi befindet sich auf einem aufstrebenden Ast
Standard

Sorry, habe SQL Server 2005 und nicht mySQL. Soweit ich weiß gibt es den Befahl EXPLAIN nicht oder doch?

ich habe jetzt aber bei SQL Server 2005 etwas gefunden. Dort sind 97% "Clustered Index Scan". Ich Sortiere nach QCES dieser ist aber nicht im Index enthalten.

Aber warum geht es bis Top >=49 und <=48 nicht. Bei der schnellen Abfrage ist auch 97% "Clustered Index Scan"

Geändert von Thisi (05.01.2009 um 14:49 Uhr).
Thisi ist offline   Mit Zitat antworten
Alt 05.01.2009, 16:52  
Erfahrener Benutzer
 
Benutzerbild von David
 
Registriert seit: 05.09.2007
Beiträge: 5.044
David wird schon bald berühmt werden
Standard

Welche Variante von SQL Server 2005 hast Du? Express, Compact, Enterprise ... ?
Und hast Du den jeweils dazugehörigen Query Analyzer zur Hand?
David ist offline   Mit Zitat antworten
Alt 05.01.2009, 22:07  
erc
Erfahrener Benutzer
 
Registriert seit: 02.01.2009
Beiträge: 730
PHP-Kenntnisse:
Fortgeschritten
erc wird schon bald berühmt werden
Standard

Zitat:
Zitat von Thisi Beitrag anzeigen
Sorry, habe SQL Server 2005 und nicht mySQL. Soweit ich weiß gibt es den Befahl EXPLAIN nicht oder doch?
Alles klar jetzt weiß ich auch warum du immer TOP geschreiben hast

Schau mal hier: SET SHOWPLAN_ALL (aber anfangen kann ich damit glaub ich nix, mssql ist nicht so mein ding) Vermutte mal ab 50 Datensätze nimmt er für die Abfrage ein index, darunter versucht ers so zu finden (warum auch immer).
erc ist offline   Mit Zitat antworten
Alt 07.01.2009, 09:53  
Neuer Benutzer
 
Registriert seit: 31.12.2008
Beiträge: 10
Thisi befindet sich auf einem aufstrebenden Ast
Standard

Ich habe die Enterpriseversion. Query Analyzer hatte ich bei der 2000 Version, jetzt bei 2005 habe ich nur das MSSQL Server Management Studio und dort habe ich ihn nicht gefunden. Heißt der hier vielleicht anders oder hätte ich ihn mit installieren können?

Ähmm, das ganze mit "SET SHOWPLAN_ALL ON" ausgeführt gibt mir doch schon einiges an Info. Leider verstehe ich da noch nicht so viel aber muss mich mal einlesen. Danke schon mal für den Tipp.
Thisi ist offline   Mit Zitat antworten
Antwort


Themen-Optionen
Thema bewerten
Thema bewerten:

Forumregeln
Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are an
Gehe zu

Ähnliche Themen
Thema Autor Forum Antworten Letzter Beitrag
Abfrage von einer Abfrage Datenbanken 5 27.01.2011 23:31
Wiemache ich eine Abfrage über 3 Tabellen??? djscaleo Datenbanken 8 05.01.2009 10:46
MySQL - Fehler in einfacher Abfrage oden Datenbanken 11 03.01.2009 20:03
MySQL Abfrage macht Seite langsam Datenbanken 11 19.10.2006 19:38
Abfrage: sortieren mit mehreren Feldern, ASC und DESC php_frage Datenbanken 3 29.04.2006 20:42
[Erledigt] mysql abfrage über 4 Tabelle - bis 3 geht, bei der 4. habert Datenbanken 2 08.09.2005 11:59
My SQL Abfrage & Ausführung per Cronjob PHP Tipps 2005 1 23.04.2005 16:08
[Erledigt] IF() abfrage in variable packen PHP Tipps 2005 14 01.04.2005 17:23
Abfrage von Char-Feldern Datenbanken 9 04.02.2005 14:06
[Erledigt] Mysql Abfrage Problem! PHP-Fortgeschrittene 5 27.11.2004 10:22
Abfrage funktioniert zwar, aber nicht korrekt Datenbanken 2 16.08.2004 09:10
Abfrage aus DB noch mal ausgeben und Abfrage aus mehrern Tab PHP Tipps 2004 4 12.07.2004 15:00
komplizierte mySQL Abfrage Datenbanken 6 25.06.2004 15:34
[Erledigt] Fehlerhafte Abfrage ? Datenbanken 15 24.06.2004 17:10
[Erledigt] mysql Abfrage Datenbanken 5 18.06.2004 14:16

Besucher kamen über folgende Suchanfragen bei Google auf diese Seite
sql desc, desc sql, sql server langsam, sql server desc, sql abfrage langsam, php mssql langsam, sql query beschleunigen, sql server beschleunigen, sql server 2005 langsam, sql abfrage beschleunigen, http://www.php.de/datenbanken/50343-sql-abfrage-ohne-desc-langsam.html, sql abfragen beschleunigen, describe sql, sql order by langsam, desc, sql abfrage mit index, microsoft sql abfragen beschleunigen, sql top \ohne top\, index langsame sql query, antwort sqlserver 2005 dauert lange

Alle Zeitangaben in WEZ +2. Es ist jetzt 04:07 Uhr.




Powered by vBulletin® Version 3.7.2 (Deutsch)
Copyright ©2000 - 2012, Jelsoft Enterprises Ltd.
Search Engine Optimization by vBSEO 3.2.0
Aprilia-Forum, Aquaristik-Forum, Liebeskummer-Forum, Zierfisch-Forum, Geizkragen-Forum