Design Meets Code

Design Meets Code

WordPress · PrestaShop

  • Startseite
  • WordPress
  • PHP / Datenbanken
  • Ubuntu
  • Prestashop
  • Grafik
  • Glossar

Prestashop: Eine CSV Datei der Bestellungen der letzten 12 Monate mit Name, Adresse und Bestellbetrag erstellen

11. Februar 2026 Leave a Comment

Eine CSV Datei mit allen Bestellungen der letzten 12 Monate, die folgende Angaben auflistet:
Vorname und Name,
PLZ und Stadt
Telefonnummer und
Wert der Bestellung
lässt sich im Backend mit einem SQL Befehl erstellen.

Erweiterte Parameter > Datenbank > SQL-Manager

Hier eine neue SQL Abfrage erstellen „Bestellungen_letzte_12_Monate“

SELECT 
    a.firstname AS 'Vorname', 
    a.lastname AS 'Name', 
    ad.postcode AS 'PLZ', 
    ad.city AS 'Stadt', 
    cl.name AS 'Land', 
    COALESCE(ad.phone, ad.phone_mobile) AS 'Telefonnummer', 
    o.total_paid_tax_incl AS 'Bestellwert', 
    o.date_add AS 'Datum'
FROM ps_orders o
LEFT JOIN ps_customer a ON (o.id_customer = a.id_customer)
LEFT JOIN ps_address ad ON (o.id_address_delivery = ad.id_address)
LEFT JOIN ps_country_lang cl ON (ad.id_country = cl.id_country AND cl.id_lang = 1)
WHERE o.date_add >= DATE_SUB(NOW(), INTERVAL 12 MONTH)
ORDER BY o.date_add DESC

Das kleine o hinter ps_orders ist ein sogenannter Alias.

Anstatt jedes Mal ps_orders.id_customer zu schreiben, reicht durch den Alias ein kurzes o.id_customer. Das macht den Code viel übersichtlicher, besonders wenn viele Tabellen im Spiel sind.

FROM ps_orders o: Hier wird festgelegt: ps_orders heißt ab jetzt o.

LEFT JOIN ps_customer a: Hier wird ps_customer der Alias a gegeben.

LEFT JOIN ps_address ad: Hier bekommt die Adress-Tabelle den Namen ad.

Der SQL Befehl COALESCE (englisch für „verschmelzen“ oder „vereinigen“) ist eine Funktion, die bedeutet „Nimm den ersten Wert, der nicht leer ist“.

Bei PrestaShop gibt es oft zwei Felder für Telefonnummern:

phone (Festnetz)

phone_mobile (Mobiltelefon)

Nicht jeder Kunde füllt beide Felder aus. Manche geben nur das Handy an, manche nur das Festnetz. Würdest du nur nach phone fragen, hättest du bei vielen Kunden ein leeres Feld in deiner CSV-Datei.
So funktioniert COALESCE(ad.phone, ad.phone_mobile):

Die Datenbank geht die Liste der Argumente von links nach rechts durch und gibt den ersten Wert zurück, der nicht NULL (leer) ist:

Die Datenbank schaut in ad.phone. Ist dort eine Nummer? Wenn ja, nimm sie und fertig.

Ist ad.phone leer (NULL)? Dann schau in ad.phone_mobile. Ist dort eine Nummer? Wenn ja, nimm diese.

Sind beide leer? Dann bleibt das Feld in deiner CSV leer.

Nach dem Speichere der Abfrage lässt sich durch Klick in der Liste daneben eine saubere CSV-Datei downloaden.

Filed Under: Prestashop Tagged With: Datenbank, MySQL

Kunden mit Adressen aus der Datenbank auslesen, die während eines bestimmten Zeitraums in einem Prestashop bestellt haben

12. März 2025 Leave a Comment

Um die Adressen und Namen der Kunden zu ermitteln, die in einem bestimmten Zeitraum in deinem PrestaShop bestellt haben, benötigst du eine SQL-Abfrage, die mehrere Tabellen miteinander verknüpft (JOINs). Hier ist eine solche Abfrage:

**SQL-Abfrage:**

SELECT 
    c.firstname, 
    c.lastname, 
    a.address1, 
    a.address2, 
    a.postcode, 
    a.city, 
    a.phone, 
    a.phone_mobile
FROM 
    `ps_orders` o
JOIN 
    `ps_customer` c ON o.id_customer = c.id_customer
JOIN 
    `ps_address` a ON o.id_address_delivery = a.id_address
WHERE 
    o.date_add BETWEEN '2023-01-01 00:00:00' AND '2023-12-31 23:59:59';
```

**Erläuterung:**

* **`SELECT c.firstname, c.lastname, a.address1, a.address2, a.postcode, a.city, a.phone, a.phone_mobile`**:
* Diese Klausel wählt die gewünschten Spalten aus: Vorname und Nachname des Kunden aus der Tabelle `ps_customer`, sowie die Adressinformationen aus der Tabelle `ps_address`.
* **`FROM \`ps_orders\` o`**:
* Beginnt mit der Tabelle `ps_orders` (Bestellungen) und gibt ihr das Alias „o“.
* **`JOIN \`ps_customer\` c ON o.id_customer = c.id_customer`**:
* Verknüpft die Tabelle `ps_orders` mit der Tabelle `ps_customer` (Kunden) basierend auf der übereinstimmenden `id_customer`.
* **`JOIN \`ps_address\` a ON o.id_address_delivery = a.id_address`**:
* Verknüpft die Tabelle `ps_orders` mit der Tabelle `ps_address` (Adressen) basierend auf der übereinstimmenden `id_address_delivery`, da dies die Lieferadresse ist.
* **`WHERE o.date_add BETWEEN ‚2023-01-01 00:00:00‘ AND ‚2023-12-31 23:59:59’`**:
* Filtert die Ergebnisse, um nur Bestellungen innerhalb des angegebenen Zeitraums einzubeziehen.

**Wichtige Hinweise:**

* **Datenbankpräfix:**
* Stelle sicher, dass du das korrekte Datenbankpräfix verwendest. Wenn dein Präfix nicht `ps_` ist, ersetze es entsprechend.
* **Datumsformat:**
* Überprüfe, ob das Datumsformat in der `WHERE`-Klausel mit dem Format der `date_add`-Spalte in deiner Datenbank übereinstimmt.
* **Adressen:**
* Bitte beachte, dass in PrestaShop verschiedene Adressarten existieren (Lieferadresse, Rechnungsadresse). Falls Rechnungsadressen benötigt werden, muss die „join bedingung“ zu „o.id\_address\_invoice = a.id\_address“ geändert werden.
* **Sicherheit:**
* Sei vorsichtig beim Ausführen von SQL-Abfragen, insbesondere in einer Produktionsumgebung. Sichere die Datenbank, bevor du Änderungen vornimmst.
* **Anpassung:**
* Du kannst die ausgewählten Spalten in der `SELECT`-Klausel nach Bedarf anpassen.

Filed Under: PHP / Datenbanken, Prestashop Tagged With: Datenbank, MySQL, Prestashop

XAMPP: MySQL startet nicht (MySQL table is marked as crashed and last repair failed)

2. Oktober 2022 Leave a Comment

Wenn der Computer unerwartet heruntergefahren wurde, kann es zu der Fehlermeldung „MySQL table is marked as crashed and last repair failed“ kommen.
Abhilfe schafft es, wenn man bei Xampp „Shell“ anklickt und hier die folgende Befehlszeile eingibt

mysqld --console --skip-grant-tables --skip-external-locking

Anschließend das Shell Fenster noch einmal öffnen und folgenden Befehl eingeben

mysqlcheck -r --databases mysql --use-frm

Quelle: Apache Friends

Filed Under: PHP / Datenbanken Tagged With: MySQL, Xampp

Anzeige

Themen

Apache BuddyPress Code Snippets Datenbank Email Enfold genesis Grid View htaccess imscp Indesign Katalogpreisregel Layout Builder LibreOffice Lieferschein List View Logout Mitgliederbereich MySQL PHP PHP Anfänger PHP Variablen Plugins Prestashop Prestashop 1.5 Prestashop 1.6 Prestashop 1.7 Prestashop 8 Prestashop Module Registrierung RSS Feed s2member Screencast Server Sicherheit ssl Startseite Strings Tipps Windows Windows 10 Windows 11 WooCommerce WooCommerce Sortierung WordPress
Anzeige

Letzte Kommentare

  • Martin bei CSS: Automatische Silbentrennung in einzelnen Wörtern verhindern
  • Martin bei CSS: Automatische Silbentrennung in einzelnen Wörtern verhindern
  • Klaus bei Woocommerce: Shop Seiten neu generieren
  • Thomas bei WordPress: Einzelne Kategorien aus dem RSS Feed ausschließen
  • Bernhard bei CSS: Automatische Silbentrennung in einzelnen Wörtern verhindern

Informationen

  • Kontakt
  • Datenschutzerklärung
  • Impressum
  • Cookie-Richtlinie (EU)
  • Kontakt
  • Datenschutzerklärung
  • Impressum
  • Cookie-Richtlinie (EU)
Anzeige