Design · PHP · Server

Design · PHP · Server

WordPress · Drupal · PrestaShop

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

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

Große Datenbanken mit ssh exportieren und wieder importieren

29. August 2024 Leave a Comment

Ab einer gewissen Größe kann das Umziehen einer Datenbank zur Nervensache werden. Oft kommt es beim Erstellen oder erst Recht beim Import einer großen Datenbank zu Abbrüchen, sobald ein gewisses Zeitlimit überschritten ist.

Einfacher geht es mit einem ssh Zugang. Einen ssh Zugang (ssh = secure shell) wird meist in den etwas anspruchsvolleren Hosting Paketen zur Verfügung gestellt. Um per ssh auf den Server zugreifen zu können, benötigt man einen ssh Client, wie z.B. Putty

Nach dem erfolgreichen Einloggen auf dem Server lassen sich Datenbanken mit folgenden Befehlen exportieren bzw. importieren:

Export

 

mysqldump -u DATENBANK-BENUTZER -p'DATENBANK-PASSWORT' --no-tablespaces --single-transaction --allow-keywords --complete-insert --insert-ignore --routines --events --force DATENBANK > SICHERUNG.SQL

DATENBANK-BENUTZER, DATENBANK-PASSWORT, DATENBANK müssen jeweils mit den Daten für die Datenbank, die gesichert werden soll, ersetzt werden.
SICHERUNG.SQL ist der Name der SQL Datei, die durch die Sicherung entsteht. Diese kann man individuell umbenennen.

Die Datenbank wird dann als SQL Datei auf dem Server abgelegt.

Import

Um die Datenbank wieder zu importieren, muss zunächst eine leere neue Datenbank erstellt werden. Mit folgendem Befehl kann dann die auf dem Server liegende Sicherungsdatei importiert werden:

mysql -u DATENBANK-BENUTZER -p'DATENBANK-PASSWORT' DATENBANK < SICHERUNG.SQL

DATENBANK-BENUTZER, DATENBANK-PASSWORT und DATENBANK müssen wieder jeweils mit den Angaben der neuen Datenbank ersetzt werden. Ebenso muss der Name SICHERUNG.SQL mit dem Namen ersetzt werden, den man für die Sicherung gewählt hat.

Filed Under: Allgemein, PHP / Datenbanken Tagged With: Code Snippets, Datenbank

Search and Replace in Database – serialized arrays in der Datenbank ersetzen

17. Oktober 2013 Leave a Comment

Es gibt Plugins, die ihre Daten als serialized arrays in der Datenbank speichern, d.h. die Zeichen des Domainnamens werden gezählt und in einem array ausgegeben. Bei einem Umzug auf eine andere Domain funktionieren die Links dann nicht mehr, da in den meisten Fällen die Zeichenkette des neuen Domainnamens eine andere Zeichenlänge hat.

Mit dem Plugin Search and Replace in Database können diese serialisierten Daten und die Zeichenlänge anpasst werden. Das Plugin steht auf der Seite interconnectit.com zum Download zur Verfügung. Es gibt auch ein Repository auf Github.

Der Download enthält die Datei searchreplacedb2.php, die nach dem Entpacken aus Sicherheitsgründen zunächst umbenannt werden sollte (z.B. in ersetzen.php). Anschließend wird sie in das Rootverzeichnis der WordPress-Installation geladen und dann direkt im Browser aufgerufen, in unserem Beispiel also meine-domain.tld/ersetzen.php. Nun muss man nur den Anweisungen auf dem Bildschirm folgen. Die Datei liest die Daten aus der wp-config.php aus, um sich mit der Datenbank zu verbinden. Anschließend hat man die Wahl, in welchen Datenbanktabellen ein bestimmter string gesucht und ersetzt werden soll. Nach der Ersetzung die Datei unbedingt wieder löschen, damit niemand auf diese Weise Zugriff auf die Datenbank erhält.
 

Für den Umzug einer WordPress Seite kann man auch das Duplicator Plugin verwenden. Hier werden serialized Daten ebenfalls automatisch ersetzt. Das Duplicator Plugin eignet sich auch sehr gut als Backup Werkzeug.

Filed Under: Allgemein Tagged With: Datenbank, Serialized Arrays, Umzug einer Domain

Anzeige

Themen

Apache Boolean values Boolesche Werte BuddyPress chmod Code Snippets Concatenation Operator Custom Post Types Datenbank Email Enfold fail2ban genesis Grid View htaccess i-mscp Indesign Layout Builder LibreOffice List View Mitgliederbereich MySQL PHP PHP Anfänger PHP Variablen Plugins Prestashop Prestashop 1.5 Prestashop 1.6 Prestashop Module Registrierung RSS Feed s2member Schreibrechte Server Shell ssl 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
Cookie-Zustimmung verwalten
Um dir ein optimales Erlebnis zu bieten, verwenden wir Technologien wie Cookies, um Geräteinformationen zu speichern und/oder darauf zuzugreifen. Wenn du diesen Technologien zustimmst, können wir Daten wie das Surfverhalten oder eindeutige IDs auf dieser Website verarbeiten. Wenn du deine Zustimmung nicht erteilst oder zurückziehst, können bestimmte Merkmale und Funktionen beeinträchtigt werden.
Funktional Immer aktiv
Die technische Speicherung oder der Zugang ist unbedingt erforderlich für den rechtmäßigen Zweck, die Nutzung eines bestimmten Dienstes zu ermöglichen, der vom Teilnehmer oder Nutzer ausdrücklich gewünscht wird, oder für den alleinigen Zweck, die Übertragung einer Nachricht über ein elektronisches Kommunikationsnetz durchzuführen.
Vorlieben
Die technische Speicherung oder der Zugriff ist für den rechtmäßigen Zweck der Speicherung von Präferenzen erforderlich, die nicht vom Abonnenten oder Benutzer angefordert wurden.
Statistiken
Die technische Speicherung oder der Zugriff, der ausschließlich zu statistischen Zwecken erfolgt. Die technische Speicherung oder der Zugriff, der ausschließlich zu anonymen statistischen Zwecken verwendet wird. Ohne eine Vorladung, die freiwillige Zustimmung deines Internetdienstanbieters oder zusätzliche Aufzeichnungen von Dritten können die zu diesem Zweck gespeicherten oder abgerufenen Informationen allein in der Regel nicht dazu verwendet werden, dich zu identifizieren.
Marketing
Die technische Speicherung oder der Zugriff ist erforderlich, um Nutzerprofile zu erstellen, um Werbung zu versenden oder um den Nutzer auf einer Website oder über mehrere Websites hinweg zu ähnlichen Marketingzwecken zu verfolgen.
Optionen verwalten Dienste verwalten Anbieter verwalten Lese mehr über diese Zwecke
Einstellungen ansehen
{title} {title} {title}