1
我正在运行一个查询,该查询将一些需要转换为JavaScript数组以便使用Google Graph的数据返回。将MySQL结果转换为Google图表的JavaScript数组
下面是该查询:
SELECT
sub.supplier_name,
(
SELECT ROUND(AVG(sp.progress), 2) as P1
FROM `sub_performancemeasures` AS sp
INNER JOIN `submissions` AS sub ON sub.id = sp.sub_id
WHERE `period` = '1'
) AS p1,
(
SELECT ROUND(AVG(sp.progress), 2) as P2
FROM `sub_performancemeasures` AS sp
INNER JOIN `submissions` AS sub ON sub.id = sp.sub_id
WHERE `period` = '2'
) AS p2,
(
SELECT ROUND(AVG(sp.progress), 2) as P3
FROM `sub_performancemeasures` AS sp
INNER JOIN `submissions` AS sub ON sub.id = sp.sub_id
WHERE `period` = '3'
) AS p3,
(
SELECT ROUND(AVG(sp.progress), 2) as P4
FROM `sub_performancemeasures` AS sp
INNER JOIN `submissions` AS sub ON sub.id = sp.sub_id
WHERE `period` = '4'
) AS p4,
(
SELECT ROUND(AVG(sp.progress), 2) as P5
FROM `sub_performancemeasures` AS sp
INNER JOIN `submissions` AS sub ON sub.id = sp.sub_id
WHERE `period` = '5'
) AS p5
FROM `submissions` AS sub
INNER JOIN `sub_performancemeasures` AS sp ON sub.id = sp.sub_id
INNER JOIN `performance_measures` AS pm ON sp.pm_id = pm.id
INNER JOIN `kpis` ON kpis.id = pm.kpi_id
GROUP BY sub.supplier_name
,该查询产生以下数组:
Array (
[0] => Array (
[sub] => Array (
[supplier_name] => C Spencer Ltd
)
[0] => Array (
[p1] => -11.43
[p2] => 36.67
[p3] =>
[p4] =>
[p5] =>
)
)
[1] => Array (
[sub] => Array (
[supplier_name] => Supplier 2
)
[0] => Array (
[p1] => 15.21
[p2] => -6.44
[p3] =>
[p4] => 65.41
[p5] =>
)
)
)
然后我需要借这个查询,并将其转换,以适应下面的JavaScript数组:
[
['Period', 'Allen', 'Tom', 'Sim'],
[1, null, null, -100],
[2, 3, null, null],
[3, 3, null, null],
[4, null, 2, null],
[5, 3, 100, null],
]
当前字符串中的数据是示例数据。我需要的阵列看起来像这样:
[
['Period', 'C Spencer Ltd', 'Supplier 2'],
[1, -11.43, 15.21],
[2, 36.67, -6.44],
[3, null, null],
[4, null, 65.41],
[5, null, null],
]
这是我到目前为止已经试过:
$str1="[['Period',";
foreach($avgSupScores as $supplier){
$str1 .= "'".$supplier['sub']['supplier_name']."', ";
//$str2 .= "1, ".$periods[0]['p1']."";
}
$str1 = rtrim($str1, ", ");
$str1 .= "],[";
echo $str1;
这导致:
[['Period','C Spencer Ltd', 'Supplier 2'],[
第一行是确定的,但我不确定该从哪里出发去获得我需要的东西,我也不确定这是否是正确/最好的方法。
您是否尝试自行转换它? – Epodax
我做了,但我没有得到任何地方。我试图用foreach循环来连接字符串 – jampez77
告诉我们你已经尝试了什么,并得到了什么错误(编辑你的问题,不要将它包含在注释中) – Epodax