1

有一个个人温度监控项目,将家中不同房间的所有温度记录到 mysql 数据库中,前几天我遇到了 highstock/charts 并一直在使用它,但我似乎无法让它处理多个系列的数据.

数据如何记录到表中;

datetime <-- (eg; 2013-07-18 15:52:26) 每个位置的每个传感器的时间都不同

位置 <-- 6 个(休息室、厨房、餐厅、户外、主人、备用)

温度 <--(例如 12.34)

mysql中的记录是什么样的;2013-07-18 15:52:26 / 大师 / 12.34

我已经设法让它全部用于一组数据,但我不确定我需要做什么以及最好的方法是如何格式化 json 和 mysql 查询,以便 highcharts 可以读取 json/mysq 数据并绘制所有一张图上有 6 个位置的温度数据。

完整的代码;主要的 highstock 图表文件。http://pastebin.com/XWkThfc8这是从 mysql 数据库生成 JSON 的文件。http://pastebin.com/RXBFr24P

这是使用上述查询的一组数据当前的样子.... [1374593356000,17.31],[1374593427000,17.25],[1374593497000,17.31],[1374593567000,17.31],[1374593638000,17.31], [1374593708000,17.25],[1374593778000,17.25],[1374593849000,17.25],[1374593919000,17000,17.25]

这是绘制一组数据的当前样子

所以我的问题是;

改变它的最佳方法是什么,以便它绘制所有数据,目前它似乎不起作用;

mysql_select_db("mqtt", $con);

$return_arr = array();

$fetch = mysql_query("SELECT timeof, message FROM temperatures WHERE DATE(timeof) BETWEEN DATE_SUB(CURDATE(), INTERVAL 7 DAY) AND CURDATE() AND locationmap = 'master'");
$i=0;
while ($row = mysql_fetch_array($fetch, MYSQL_ASSOC)) {
$rows[$i]=array(strtotime($row[timeof])*1000 ,(float)$row[message]);
$i++;
}

echo json_encode($rows);

我假设它需要采用这种格式的多组数据。

[{name:'kitchen',dat‌​a:[[date,temp],[date,temp],[date,temp]]},{name:'lounge',dat‌​a:[[date,temp] ,[日期,温度],[日期,温度]]}]

不知道如何更改我的查询,以便它为所有位置提取数据,然后正确编码。

更新-1

最新代码,

$return_arr = array();

$fetch = mysql_query("SELECT timeof, locationmap AS location, message AS temp FROM temperatures WHERE DATE(timeof) BETWEEN DATE_SUB(CURDATE(), INTERVAL 1 DAY) AND CURDATE() ORDER BY location, timeof ASC");
$i=0;
while ($row = mysql_fetch_array($fetch, MYSQL_ASSOC)) {
$rows[$i]=array(strtotime($row[timeof])*1000 ,(float)$row[temp],$row[location]);
$i++;
}

echo json_encode($rows);   

但是,它不会返回上面提到的正确格式。

它是这样出来的。(显然有 1000 个整体。)

[1375272426000,22.63,"cupboard"],[1375272496000,22.69,"cupboard"],[1375272566000,22.75,"cupboard"],[1375272637000,22.75,"cupboard"],[1375272707000,22.69,"cupboard"],[1375272777000,22.63,"cupboard"],[1375106429000,17.69,"kitchen"],[1375106500000,17.69,"kitchen"],[1375106570000,17.63,"kitchen"],[1375106640000,17.63,"kitchen"],[1375106711000,17.63,"kitchen"],[1375106781000,17.63,"kitchen"],[1375106851000,17.63,"kitchen"],[1375106921000,17.56,"kitchen"],[1375106992000,17.56,"kitchen"],[1375107062000,17.56,"kitchen"],[1375107132000,17.56,"kitchen"],[1375107203000,17.56,"kitchen"],[1375107273000,17.5,"kitchen"],[1375107343000,17.5,"kitchen"],[1375107413000,17.5,"kitchen"]

我认为我的查询现在是正确的!??只需要一些关于 json 输出的帮助!

UPDATE-2 感谢 highcharts 论坛,这是我需要 JSON 的格式,只需要 php/mysql 方面的帮助...

[{
  name: 'kitchen',
  data: [
    [time, value],
    [time, value]
  ]
}, {
  name: 'attic',
  data: [
    [time, value],
    [time, value]
  ]
}]

UPDATE-3 让它与多个系列数据一起工作,我不必多次调用我的 json php 脚本,已将这两个文件放在 GIST 上,以供遇到类似问题的任何人使用。

http://i.imgur.com/PzcTCGg.png

https://gist.github.com/matbor/8854385 https://gist.github.com/matbor/8853902

4

3 回答 3

1

是的,它应该采用您包含的格式,而且日期应该是时间戳(以毫秒为单位的时间)并且 temp 需要数值。

于 2013-07-18T13:44:18.507 回答
1

我认为最好的方法是遵循“比较演示”并让您的 php 代码仅生成一个数组,具体取决于指定房间的 url 参数:

json.php?room=attic
json.php?room=cupboard

一个你只输出房间的数据

然后,highstocks 使用以下命令调用单独的 php 文件:

names = ['attic', 'cupboard', '...'],

$.each(names, function(i, name) {

    $.getJSON('jsonp.php?room='+ name.toLowerCase() +'-c.json&callback=?',  function(data) {
...

但老实说,我仍在寻找一种方法来避免多次 http 调用/sql 查询 :-) 特别是对于 [date1,value1,value1,value3],[date2,value1,value1,value3] 等数据...

于 2014-02-03T16:43:56.967 回答
0

我已经使用这个项目大约 6 个月了,我想我会分享一些其他人可能会觉得方便的小技巧。
一切都运行得非常好,我有 5 个树莓派将温度数据记录到 CentOS 服务器上的 MYSQL 数据库中,但它突然坏了。该页面根本不会显示任何内容,但在“网络”选项卡下的 Firefox 开发人员工具控制台中,我可以看到 5 个数据库查询中有 3 个导致 500 内部服务器错误。
这看起来很奇怪,因为我没有修改任何东西,一些故障排除最终导致我访问 httpd error_log。有一个 php 错误,表明最大内存分配已用尽。

PHP 致命错误:/var/www/html/temperatures/json_hs_temps.php 中允许的内存大小为 134217728 字节已用尽(尝试分配 757 字节)

我在 json_hs_temps.php 文件中添加了以下代码行,以将内存从默认的 128Mb 增加到 1Gb。

ini_set('memory_limit', '1024M');

这立即解决了问题,并且图表再次正常加载。

此外,由于以下时区错误,httpd error_log 也变得很大(千兆字节):

PHP 警告:strtotime():依赖系统的时区设置是不安全的。您需要使用 date.timezone 设置或 date_default_timezone_set() 函数。如果您使用了这些方法中的任何一种,但仍然收到此警告,您很可能拼错了时区标识符。我们现在选择时区“UTC”,但请设置 date.timezone 以选择您的时区。在 /var/www/html/temperatures/json_hs_temps.php 第 27 行,引用:http: //192.168.178.49/temperatures/index_hs_temps_multi.php

解决方案是将以下代码行添加到 json_hs_temps.php 文件中以设置时区。

date_default_timezone_set("Australia/Hobart");

我认为这可能会发生在使用此代码的其他人身上,所以我希望它可以帮助其他人。

于 2019-03-13T10:27:36.293 回答