Ein Händler möchte z.B. in seinem Shop mit weit über tausend Artikeln die Preise dauerhaft um einen bestimmten Prozentbetrag senken. Die folgende SQL-Abfrage senkt den Preis aller Artikel um 20%:
UPDATE catalog_product_entity_decimal SET value = value * 0.8;
Nach einer solchen Abfrage wird der neue Preis zunächst als Sonderpreis dargestellt, d.h. der alte Preis ist im Shop weiterhin sichtbar und erscheint durchgestrichen über dem neuen Preis.
Damit der alte Preis vollständig verschwindet, muss die Indextabelle mit Artikelpreisen aktualisiert werden. Hierzu in System > Index-Verwaltung in der Zeile Artikelpreise auf Neuaufbau klicken.
Nachtrag vom 07.02.2012
Sicherheitshalber sollte die Anfrage auf die Artikelpreise beschränkt werden. Die richtige attribute_id kann auch über die Abfrage der Tabelle catalog_product_entity_decimal an den Ihnen bekannten Produktpreisen in der Spalte value erkannt werden. In meinem Fall ist das die 64:
UPDATE catalog_product_entity_decimal SET value = value * 0.8 WHERE attribute_id = 64;
Wer es ganz automatisch haben möchte, bekommt die attribute_id über eine Unterabfrage:
UPDATE catalog_product_entity_decimal SET value = value * 0.8 WHERE attribute_id = ( SELECT attribute_id FROM eav_attribute WHERE attribute_code = "price" );
Ich würde noch nach attribute_id filtern da sonst nicht nur der Preis reduziert wird.
Guten Morgen,
Ich habe eine Frage, bin aber nicht sicher ob ich hier richtig bin und versuche es einfach.
Wir möchten in unserem Shop in der Kategorie „Sales“ bei einzelnen Artikeln einen Aktionspreis so einrichten, das der ursprüngliche Preis ebenfalls (nur durchgestrichen) erscheint.
Gibt es innerhalb Magento diese Möglichkeit oder ist dafür eine Erweiterung erforderlich?
Herzlichen Dank.
Der Streichpreis wird doch standardmäßig angezeigt. Ansonsten ließe sich eine Modifikation direkt in das Template einbauen. Eine Erweiterung nur für diese Funktion wäre zu viel.