Cookies op Tweakers

Tweakers is onderdeel van DPG Media en maakt gebruik van cookies, JavaScript en vergelijkbare technologie om je onder andere een optimale gebruikerservaring te bieden. Ook kan Tweakers hierdoor het gedrag van bezoekers vastleggen en analyseren. Door gebruik te maken van deze website, of door op 'Cookies accepteren' te klikken, geef je toestemming voor het gebruik van cookies. Wil je meer informatie over cookies en hoe ze worden gebruikt? Bekijk dan ons cookiebeleid.

Meer informatie
Toon posts:

[MySQL] Window actieve contracten optellen met interval

Pagina: 1
Acties:

Onderwerpen

Vraag


  • BasXcore
  • Registratie: april 2002
  • Laatst online: 16-06 23:02
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



Apple iPad Pro (2021) 11" Wi-Fi, 8GB ram Microsoft Xbox Series X LG CX Google Pixel 5a 5G Sony XH90 / XH92 Samsung Galaxy S21 5G Sony PlayStation 5 Nintendo Switch Lite

Tweakers vormt samen met Hardware Info, AutoTrack, Gaspedaal.nl, Nationale Vacaturebank, Intermediair en Independer DPG Online Services B.V.
Alle rechten voorbehouden © 1998 - 2021 Hosting door True