我正在尝试使用chart.js和mssql数据库绘制条形图。我能够从数组中的数据库中检索数据。我使用了以下代码,
<?php
$serverName = "PC";
$uid = "sa";
$pwd = "PC#1234";
$databaseName = "climate";
$dsn = "sql";
$conn= odbc_connect ($dsn ,$uid ,$pwd);
if(!$conn){
echo('Connection Failed');
}
$sql="select convert(nvarchar(100), DVCDTxp_Datetime,106) )";
$rs=odbc_exec($conn,$sql);
if (!$rs){
exit("Error in SQL");
}
echo odbc_result_all($rs);
$response = array();
for($i=1;$i<= odbc_num_rows($rs);$i++){
$row = odbc_fetch_array($rs,$);
$response[] = $row;
}
?>
我得到以下输出,
DATE AVG_VAL
06 Jun 2015 5.466593
08 Jun 2015 1.774121
09 Jun 2015 .729223
11 Jun 2015 3.329457
12 Jun 2015 2.344660
我想要以下输出,
DATE=["06 Jun 2015","08 Jun 2015","09 Jun 2015","11 Jun 2015","12 Jun 2015"]
VALUE=["5.466593","1.774121",".729223","3.329457","2.344660"]
答案 0 :(得分:0)
您正在创建数组$response
,因此假设数组键被索引并从零开始。
如果没有,请在回显时在array_values()
内使用json_encode()
。
$all_dates = array_map(function($val){ return $val['DATE']; }, $response);
$all_values = array_map(function($val){ return (float)$val['AVG_VAL']; }, $response);
使用as,
DATE = <?php echo json_encode($all_dates)?>
VALUE = <?php echo json_encode($all_values)?>
答案 1 :(得分:0)
我不习惯odbc_fetch_array,但我认为应该是$ i而不仅仅是$
此外,如果您可以获取记录,则可以使用array_push()将数据存储为
$date=array();
$value=array();
在你的for循环中
array_push($date,$row['date']);
array_push($value,$row['avg_value']);
答案 2 :(得分:0)
如果您的$response
处于这种形状,也许array_column可以提供帮助:
$response = array(
array("DATE" => "06 Jun 2015", "AVG_VAL" => 5.466593),
array("DATE" => "08 Jun 2015", "AVG_VAL" => 1.774121),
array("DATE" => "09 Jun 2015", "AVG_VAL" => 0.729223),
array("DATE" => "11 Jun 2015", "AVG_VAL" => 3.329457),
array("DATE" => "12 Jun 2015", "AVG_VAL" => 2.344660)
);
$date = array_column($response, 'DATE');
$value = array_column($response, 'AVG_VAL');