Heim  >  Artikel  >  Datenbank  >  Wie ruft eine MySQL-Self-Join-Abfrage Daten ab, die sich auf das Enddatum eines Ereignisses beziehen?

Wie ruft eine MySQL-Self-Join-Abfrage Daten ab, die sich auf das Enddatum eines Ereignisses beziehen?

Patricia Arquette
Patricia ArquetteOriginal
2024-11-10 16:18:03233Durchsuche

How does a MySQL self-join query retrieve data related to an event's end date?

Den Mechanismus von MySQL-Self-Join-Abfragen verstehen

Self-Join-Abfragen beinhalten die Verknüpfung zweier Instanzen derselben Tabelle, um verwandte Elemente zu vergleichen oder abzurufen Daten. Sehen wir uns die Einzelheiten der von Ihnen vorgestellten SQL-Abfrage genauer an:

``
SELECT event2.id, event2.startdate, event2.price
FROM mm_eventlist_dates event1
JOIN mm_eventlist_dates event2
ON event2.startdate = date_add(event1.enddate, INTERVAL 1 TAG)
WHERE event1.id=$id
``

Eintauchen in die Teile:

  • VON: Gibt die zu verbindenden Tabellen an. In diesem Fall sind beide Instanzen von „mm_eventlist_dates“-Tabellen. Wir bezeichnen sie als „Ereignis1“ und „Ereignis2“, um Verwirrung zu vermeiden.
  • JOIN: Verknüpft die Zeilen von „Ereignis1“ mit „Ereignis2“ basierend auf der angegebenen Bedingung.
  • ON: Definiert die Join-Bedingung, die in dieser Abfrage gilt ist:

    • event2.startdate = date_add(event1.enddate, INTERVAL 1 DAY)
    • Diese Bedingung stimmt mit Zeilen von „event2“ überein, deren Startdaten einen Tag nach den Enddaten von liegen Reihen hinein 'event1'.
  • WHERE: Filtert die Ergebnisse, um nur Zeilen einzuschließen, in denen 'event1.id' mit der angegebenen $id übereinstimmt.

So funktioniert es Schritt für Schritt:

  1. Die Abfrage startet durch Identifizieren der Zeile in „event1“, die mit dem angegebenen $id-Parameter übereinstimmt.
  2. Für jede übereinstimmende Zeile in „event1“ berechnet es das Enddatum plus einen Tag mithilfe der Funktion date_add(), der das Startdatum darstellt der zugehörigen Zeile in „Ereignis2“.
  3. Die Zeile „Ereignis1“ wird dann mit Zeilen in „Ereignis2“ verbunden, in denen die Startdaten mit dem berechneten Datum aus Schritt übereinstimmen 2.
  4. Schließlich wählt die Abfrage bestimmte Spalten (ID, Startdatum und Preis) aus den übereinstimmenden Zeilen in „event2“ aus.

Beispielszenario:

Betrachten Sie eine Tabelle mit den folgenden Ereignisdaten:

ID Start Date End Date Price
1 2023-03-01 2023-03-10 0
2 2023-03-15 2023-03-22 0
3 2023-04-01 2023-04-08 0

Wenn Sie Wenn Sie die Abfrage mit $id auf 1 ausführen, werden die Daten für Ereignis 2 abgerufen, das einen Tag nach dem Enddatum von Ereignis 1 beginnt:

ID Start Date Price
2 2023-03-15 0

Das obige ist der detaillierte Inhalt vonWie ruft eine MySQL-Self-Join-Abfrage Daten ab, die sich auf das Enddatum eines Ereignisses beziehen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn