Das kann ich nicht wirklich sagen. Wenn es klein geschrieben ist, dann ist es noch eine xt Commerce Alt-Last. Habs mit aufgenommen und werde das mal Client und Serverseitig mit rund 1,5 Mio artikeln durchmessen.
Schonmal danke für den Hinweis.
Das kann ich nicht wirklich sagen. Wenn es klein geschrieben ist, dann ist es noch eine xt Commerce Alt-Last. Habs mit aufgenommen und werde das mal Client und Serverseitig mit rund 1,5 Mio artikeln durchmessen.
Schonmal danke für den Hinweis.
hmmmm, einfach auf "Suchen" klicken bringt bei mir die Meldung das etwas fehlt.
Habe ich Dich falsch verstanden?
hmmmm, einfach auf "Suchen" klicken bringt bei mir die Meldung das etwas fehlt.
In welchem Shop?
distinct an der Stelle kleingeschrieben, findet sich auch in osc und xtcmodified code so, also alt.
http://dev.mysql.com/doc/refman/5.1…timization.html
7.2.8. Optimierung von DISTINCT
DISTINCT kombiniert mit ORDER BY benötigt in vielen Fällen eine Temporärtabelle.
...
incudes/classes/product.php
ZitatAlles anzeigen$product_query = xtc_db_query("SELECT *
FROM
".TABLE_PRODUCTS." AS p JOIN
".TABLE_PRODUCTS_DESCRIPTION." AS pd ON p.products_status = '1'
AND
p.products_id = '".$this->pID."'
AND
pd.products_id = p.products_id ".$group_check."
AND
pd.language_id = '".(int)$_SESSION['languages_id']."'");
Diese Datenbankabfrage mit "SELECT *" könnte man doch auch noch optimieren.
Ich kann in dieser Abfrage zum Beispiel mindestens auf 6-7 Spalten aus der Tabelle PRODUCTS verzichten (Videos, EAN, FSK18 etc.)
Ich hatte mal das * mit den Spaltennamen ersetzt aber das funktionierte nicht, da ich von Joins keine Ahnung habe.
Wie müsste denn die Abfrage aussehen, wenn man die einzelnen Spalten angibt?
z.B. p.products_id, pd.name, ....
oder wenn man Spaltennamen im Ergebnis anders benennen will:
p.products_id AS produktnummer, pd.name AS produktname, ...
Naja, bei einem einzigen Produkt als Ergebnisliste ist das wohl hier eher zu vernachlässigen und würde es komplizierter machen, da die Felder dieser Abfrage sicherlich in vielen Templates verwendet werden.
Ein Tipp zur optimierung der advanced_search_result.php
das ist mehr als spürbar bei mehr als 1000 Artikel.
multisort ist das Problem alle GROUP BY pd.products_id ändern in GROUP BY p.products_id
Zeile 244 bis 268 austauschen
switch ($_GET['multisort']){
case 'new_asc':
$order_str = 'GROUP BY p.products_id ORDER BY p.products_date_added ASC';
break;
case 'new_desc':
$order_str = 'GROUP BY p.products_id ORDER BY p.products_date_added DESC';
break;
case 'name_asc':
$order_str = 'GROUP BY p.products_id ORDER BY pd.products_name ASC';
break;
case 'name_desc':
$order_str = 'GROUP BY p.products_id ORDER BY pd.products_name DESC';
break;
case 'price_asc':
$order_str = 'GROUP BY p.products_id ORDER BY p.products_price ASC';
break;
case 'specialprice':
$order_str = 'GROUP BY p.products_id ORDER BY s.specials_new_products_price DESC';
break;
case 'price_desc':
$order_str = 'GROUP BY p.products_id ORDER BY p.products_price DESC';
break;
default:
$order_str = ' GROUP BY p.products_id ORDER BY pd.products_name';
}
Hatte das mal in den Bugtracker geschrieben, hat aber niemanden interssiert!?
Habe das mal getestet, aber einen wirklichen Performance Spung kann ich nicht entdecken. Bei 30.000 Artikeln bleibt die SQL Zeit gleich. Können es aber auch gern mit aufnehmen, wenn es Sinn macht.
Das sollte nichts ändern. Das entfernen des DISTINCTs in der advanced_search_result.php ist dagegen sinnig.
Bring bei 30.000 Produkten immerhin ca. 30% Verbesserung.
Nur mal der Vollständigkeit halber. Das DISTINCT legt eine Temporäre Tabelle an um doppelte Treffer herauszufiltern. Geht bei mehreren 10'000 Artikeln imens auf die Hardware.
admin
@siekiera
bei nur einer Sprache bringt das sicher nicht so viel aber bei 2 oder mehr Sprachen war es bei mir viel schneller (5400 Artikel).
1) GROUP BY pd.products_id ändern in GROUP BY p.products_id
2) DISTINCT raus
denn eine p.products_id kann überhaupt nicht doppelt ausgegeben werden.
Der aktivierte Cache macht probleme bei wortwolke, somit ist man gezwungen den cache auszuschalten, was dazu führt, das die bestsellerbox die performance erheblich beieinträchtigt. Ein Fix wäre toll
Welches Problem?
egal welchen tag du anklickst, du landest beim gleichen tag