Toon posts:

[MySQL] Window actieve contracten optellen met interval

Pagina: 1
Acties:

Onderwerpen

Vraag


  • BasXcore
  • Registratie: April 2002
  • Laatst online: 05-12 15:45
Ik heb een MySQL database met oa een customers en customer_contracts tabel.

De customer_contracts tabel ziet er als volgt uit:
nametype
idint(11)
customerint(11)
namevarchar(128)
startdatedate
enddatedate


Nu wil ik in Grafana een grafiek maken waarin op interval (bijvoorbeeld op dag) je het aantal contracten dat valt in de startdate en enddate range optelt.

Dit is een simpele query dat laat zien hoe ik kan bepalen hoeveel contracten op een bepaald moment actief zijn.
code:
1
2
3
4
5
6
7
SELECT
COUNT(*) AS 'Contracts'
FROM `customer_contracts`
JOIN customers ON customer_contracts.customer = customers.id
WHERE customers.deleted = 0
AND customer_contracts.deleted = 0
AND enddate > '2020-11-01'


Daar dient iets van een windowing / paritionering aan toegevoegd worden zodat je op interval (bv van een dag) hoeveel contracten op die dagen actief zijn. Echte gaat dit mijn kennis te boven, enige hulp hierbij is heel erg welkom.

Alvast bedankt,
Bastiaan

Alle reacties


Acties:
  • 0Henk 'm!

  • pedorus
  • Registratie: Januari 2008
  • Niet online
Je hebt denk ik een hulptabel nodig met alle datums, of beter de datums waarvoor je wil rapporteren. Zie bijvoorbeeld https://stackoverflow.com...ble-with-a-range-of-dates (met https://stackoverflow.com/a/45992247 kan het in theorie zelfs zonder echte tabel).

Als je die hebt kun je daarmee een join doen op basis van date>=startdate and date<=enddate en een count(*) + group by date ofzo.

Vitamine D tekorten in Nederland | Middelen tegen corona



Tweakers maakt gebruik van cookies

Tweakers plaatst functionele en analytische cookies voor het functioneren van de website en het verbeteren van de website-ervaring. Deze cookies zijn noodzakelijk. Om op Tweakers relevantere advertenties te tonen en om ingesloten content van derden te tonen (bijvoorbeeld video's), vragen we je toestemming. Via ingesloten content kunnen derde partijen diensten leveren en verbeteren, bezoekersstatistieken bijhouden, gepersonaliseerde content tonen, gerichte advertenties tonen en gebruikersprofielen opbouwen. Hiervoor worden apparaatgegevens, IP-adres, geolocatie en surfgedrag vastgelegd.

Meer informatie vind je in ons cookiebeleid.

Sluiten

Toestemming beheren

Hieronder kun je per doeleinde of partij toestemming geven of intrekken. Meer informatie vind je in ons cookiebeleid.

Functioneel en analytisch

Deze cookies zijn noodzakelijk voor het functioneren van de website en het verbeteren van de website-ervaring. Klik op het informatie-icoon voor meer informatie. Meer details

janee

    Relevantere advertenties

    Dit beperkt het aantal keer dat dezelfde advertentie getoond wordt (frequency capping) en maakt het mogelijk om binnen Tweakers contextuele advertenties te tonen op basis van pagina's die je hebt bezocht. Meer details

    Tweakers genereert een willekeurige unieke code als identifier. Deze data wordt niet gedeeld met adverteerders of andere derde partijen en je kunt niet buiten Tweakers gevolgd worden. Indien je bent ingelogd, wordt deze identifier gekoppeld aan je account. Indien je niet bent ingelogd, wordt deze identifier gekoppeld aan je sessie die maximaal 4 maanden actief blijft. Je kunt deze toestemming te allen tijde intrekken.

    Ingesloten content van derden

    Deze cookies kunnen door derde partijen geplaatst worden via ingesloten content. Klik op het informatie-icoon voor meer informatie over de verwerkingsdoeleinden. Meer details

    janee