我正在尝试将我的家庭温度表输出为 json 格式。仅使用 WHERE 使用一个位置时,我已成功输出到 json,但我似乎无法正确输出代码并按位置对其进行分组,如下例所示。
使用包含此类数据的大型 mysql 表
--------------------------------------
|timeof |temp |location |
|--------------------------------------|
|2013-09-30 00:46:45 | 10.34 | outside |
|2013-09-30 00:43:45 | 18.34 | kitchen |
|2013-09-30 00:41:45 | 11.34 | outside |
|2013-09-30 00:42:34 | 19.34 | lounge |
|2013-09-30 00:41:45 | 11.34 | outside |
|.....
然后使用下面的 php 代码和 mysql 查询,我相信我使用的是正确的查询,但是我的 JSON 格式是一团糟!
$fetch= mysql_query("
Select
location,
Group_Concat(timeof,temp)
From
temperatures
Group By
location
");
$result = array($name => array());
while ($row = mysql_fetch_assoc($fetch))
$result[$location][] = $row;
echo json_encode($result);
上面的代码正在生成这个 JSON 输出,但这不是我需要的方式;
{"":[{"location":"outside","Group_Concat(timeof,temp)":"2013-08-03
04:51:5619.31,2013-07-23 14:51:5221.63,2013-08-03 09:51:5421.06,2013-07-23
19:51:5122.00,2013-08-03 14:51:5222.69,2013-07-24 00:51:4921.31,2013-08-03
16:03:0021.69,2013-08-06 07:51:2616.44,2013-07-14 20:45:2322.75,2013-07-26
16:52:4118.38,2013-07-15 01:27:4622.38,2013-08-06 12:51:2416.56,2013-07-26"},
{"location":"kitchen","Group_Concat(timeof,message)":"2013-07-23 11:52:3017.31,
2013-09-29 18:50:3319.63,2013-08-25 01:07:1217.13,2013-10-22 11:14:3217.06,
2013-08-03 06:52:3114.44,2013-08-14 00:30:3417.31,2013-09-04 20:09:5921.13,2013-09-18
这就是我真正需要 JSON 输出出现的方式;
[{name: location,data: [ [timeof, temp],[timeof, temp],[timeof, temp] ]}, {name: location,data: [ [timeof, temp],[timeof, temp],[timeof, temp] ]}]
关于我需要改变什么以获得正确的输出有什么想法吗?