Mysql
 sql >> Datenbank >  >> RDS >> Mysql

PHP/MySQL:Wiederkehrende Ereignisse in einer Datenbank modellieren, aber Datumsbereiche abfragen

Ich würde eine Tally-Tabelle mit nur einer Spalte namens id erstellen und füllen Sie diese Tabelle mit Zahlen von 0 bis 500. Jetzt können wir das ganz einfach verwenden, um Auswahlen zu treffen, anstatt eine While-Schleife zu verwenden.

Id
-------------------------------------
0
1
2
etc...

Dann würde ich die Ereignisse in einer Tabelle mit Name as varchar speichern , startdate as datetime und repeats as int

Name    | StartDate            |   Repeats
-------------------------------------
Meeting | 2012-12-10 00:00:00  |   7
Lunch   | 2012-12-10 00:00:00  |   1

Jetzt können wir die Tally-Tabelle verwenden, um alle Daten zwischen zwei Daten auszuwählen, indem wir Folgendes verwenden:

SELECT DATE_ADD('2012-12-09 00:00:00',INTERVAL Id DAY) as showdate
FROM `tally`
WHERE (DATE_ADD('2012-12-09 00:00:00',INTERVAL Id DAY)<='2012-12-20 00:00:00')
ORDER BY Id ASC
ShowDate
-------------------------------------
2012-12-09 00:00:00
2012-12-10 00:00:00
2012-12-11 00:00:00
2012-12-12 00:00:00
2012-12-13 00:00:00
2012-12-14 00:00:00
2012-12-15 00:00:00
2012-12-16 00:00:00
2012-12-17 00:00:00
2012-12-18 00:00:00
2012-12-19 00:00:00
2012-12-20 00:00:00

Dann verbinden wir dies mit der Ereignistabelle, um die Differenz zwischen dem Startdatum und dem Ausstellungsdatum zu berechnen. Wir haben die Ergebnisse davon durch die repeats geteilt Spalte und wenn der Rest 0 ist , wir haben eine Übereinstimmung.

Alles kombiniert wird zu:

SELECT E.Id, E.Name, E.StartDate, E.Repeats, A.ShowDate, DATEDIFF(E.StartDate, A.ShowDate) AS diff
FROM events AS E, (
    SELECT DATE_ADD('2012-12-09 00:00:00',INTERVAL Id DAY) as showdate
    FROM `tally`
    WHERE (DATE_ADD('2012-12-09 00:00:00',INTERVAL Id DAY)<='2012-12-20 00:00:00')
    ORDER BY Id ASC
) a
WHERE MOD(DATEDIFF(E.StartDate, A.ShowDate), E.Repeats)=0
AND A.ShowDate>=E.StartDate

Was zu

führt
Id  | Name       |StartDate             | Repeats   | ShowDate              | diff
---------------------------------------------------------------------------------
1   | Meeting    | 2012-12-10 00:00:00  | 7         | 2012-12-10 00:00:00   | 0
2   | Lunch      | 2012-12-10 00:00:00  | 1         | 2012-12-10 00:00:00   | 0
2   | Lunch      | 2012-12-10 00:00:00  | 1         | 2012-12-11 00:00:00   | -1
2   | Lunch      | 2012-12-10 00:00:00  | 1         | 2012-12-12 00:00:00   | -2
2   | Lunch      | 2012-12-10 00:00:00  | 1         | 2012-12-13 00:00:00   | -3
2   | Lunch      | 2012-12-10 00:00:00  | 1         | 2012-12-14 00:00:00   | -4
2   | Lunch      | 2012-12-10 00:00:00  | 1         | 2012-12-15 00:00:00   | -5
2   | Lunch      | 2012-12-10 00:00:00  | 1         | 2012-12-16 00:00:00   | -6
1   | Meeting    | 2012-12-10 00:00:00  | 7         | 2012-12-17 00:00:00   | -7
2   | Lunch      | 2012-12-10 00:00:00  | 1         | 2012-12-17 00:00:00   | -7
2   | Lunch      | 2012-12-10 00:00:00  | 1         | 2012-12-18 00:00:00   | -8
2   | Lunch      | 2012-12-10 00:00:00  | 1         | 2012-12-19 00:00:00   | -9
2   | Lunch      | 2012-12-10 00:00:00  | 1         | 2012-12-20 00:00:00   | -10

Jetzt könnten (und sollten!) Sie die Dinge beschleunigen. Zum Beispiel durch direktes Speichern von Daten in einer Tabelle, sodass Sie einfach alle Daten direkt auswählen können, anstatt eine Strichliste mit dateadd zu verwenden. Alles, was Sie zwischenspeichern können und nicht erneut berechnen müssen, ist gut.