O n Thu, 2013-12-12 at 12:45 -0600, Seb wrote:I 'm working on the design of a database for time series data collected -- Et in Arcadia, ego. Floripa -- city of Land Rovers and alligators swimming in creeks. > sampling scheme, but not all. I initially thought it would be a good > idea to have a table identifying each parameter (variable) that the > sensors report on: > > CREATE TABLE parameters ( > parameter_id serial PRIMARY KEY, > parameter_name character_varying(200) NOT NULL, > ... > ) > > and then store the data in a table referencing it: > > CREATE TABLE series ( > record_id serial PRIMARY KEY, > parameter_id integer REFERENCES parameters, > reading ???? > ... > ) > > but of course, the data type for the parameters may vary, so it's > impossible to assign a data type to the "reading" column. The number of > variables measured by the sensors is quite large and may grow or > decrease over time, and grouping them into subjects (tables) is not > clear, so it's not simple to just assign them to different columns. > > I've been trying to search for solutions in various sources, but am > having trouble finding relevant material. I'd appreciate any advice. > > Cheers, > > -- > Seb > > Hello Seb, I am not a meteorologist and don't know "how" your sensors function, so please bear with me. I am assuming each sensor reading consists of an identifier, a timestamp and a numeric value. As a first cut:- 1) a table to hold type of sensor and its reading metric. E.g, degrees celsius, kph, litres/minute, etc. Maybe also hold min and max ranges for validation purposes. E.g. wind direction would have a range of zero to 359. 2) a table to hold geographic location of sensor with a FK pointing to its type. You could hold its latitude and longitude. Its "identifier" matches the identifier returned by a reading. 3) a table to hold the readings with a FK pointing to its geographical location with the actual reading held in a NUMBER(7,3) column, say? 4) a view over these tables using straightforward cartesian joins. Use the view for analysis. E.g., if you were going to build an airfield you know the location so you can graph your wind rose by obtaining wind direction and velocity each day for 'n' days. The only fly in the ointment with this is a rain gauge. If you don't empty it each day the actual rainfall is the difference between readings. HTH. Cheers, Robert -- Sent via pgsql-general mailing list (pgsql-general@xxxxxxxxxxxxxx) To make changes to your subscription: http://www.postgresql.org/mailpref/pgsql-general