From: Eugene Crosser Date: Sun, 20 Dec 2015 21:11:55 +0000 (+0300) Subject: change scheme to use sum of adjustments X-Git-Url: http://average.org/gitweb/?a=commitdiff_plain;h=f6a4965a22830a74cfbcc9b0b549d71d976bf5cb;p=pulsecounter.git change scheme to use sum of adjustments --- diff --git a/DATABASE b/DATABASE index 4108c08..b498c2a 100644 --- a/DATABASE +++ b/DATABASE @@ -57,3 +57,32 @@ mysql: +---------------------+-------+ 6 rows in set (0.00 sec) +2015-12-20: + +After some playing with it, I think it is a mistake. One of my assumed +goals was minimize carrying state along time. This is achieved in the +`counter` table, but not in `adjustment` table. Namely, when you need to +adjust before one or more later adjustments, you'd have to update the +later adjustment records. Advantage of this approach is that you need +to select just one row from the `adjustment` table in addition to the +row of the `counter` table. Disadvantage is as stated above, departure +from the "write only" principle. + +So I am changing the design to this: + + +select timestamp, value+adj as value from + (select c.timestamp timestamp, c.value value, + (select sum(value) from adjustment a + where a.timestamp <= c.timestamp + ) adj from counter c + ) t; + +so every row in the `adjustment` table contains incremental offset, +typically simply the last recorded value of the counter (unless some +events where lost while the sensor was down). Select is potentially +more expensive; given that I do not anticipate many adjustments this +should not be a problem for a single-user setup. For "industrial +size" setup, the problem is easily solved caching the result of the +"summing" select. + diff --git a/select.sql b/select.sql new file mode 100644 index 0000000..88bcba4 --- /dev/null +++ b/select.sql @@ -0,0 +1,12 @@ +select to_seconds(timestamp) as time, value+adj as value from + (select c.timestamp timestamp, c.value value, + (select sum(value) from coldadj a + where a.timestamp <= c.timestamp + ) adj from coldcnt c order by timestamp + ) t; +select to_seconds(timestamp) as time, value+adj as value from + (select c.timestamp timestamp, c.value value, + (select sum(value) from hotadj a + where a.timestamp <= c.timestamp + ) adj from hotcnt c order by timestamp + ) t;