If I store the data every sec开发者_StackOverflowond, the database will grow rapidly. I need to have less detail of measurements of a few weeks/months back. An average would be enough. I have 5 sensors: wind speed, wind direction, temperature, light and rain. How would I design my database?
Well, I'd design a table for the current data and then tables with aggregated data. Every once in a while (maybe a nighly/weekly/monthly run) I'd aggregate the data, write it to the tables and delete it from the current data.
I'd have exactly the same table (fields: measurement id, wind speed, wind direction, temperature, light and rain, timestamp) for each aggregation level I need.
- measurements_weekly
- measurements_daily_average
- measurements_weekly_average
- measurements_monthly_average
- measurements_yearly_average
This has several advantages: The data can be managed separately (Backup/detailed reports etc.). You just need one aggregation procedure for all aggregation levels and run it with different timespans and tables as arguments. Queries on any table and thus analysis will be fast and performant.
If you dislike the seemingly redundant structures, two tables can be enough as well: one for the measurements and one for the aggregated measurements, which must then include a timespan. But this approach will introduce complexity to your aggregation routines and any analysis, thus I would not use it.
精彩评论