How to fetch MySQL Data via PHP to display a Google Line Chart? Here is the code to select multiple data rows from the sql server. These are getting formatted and displayed as a good looking google line chart via javascript code.
Inhaltsverzeichnis
Code
$depotwert = "[['Tag', 'Depotwert'],"; $sql4 = "SELECT * FROM depotvalue WHERE depotid = $depotid"; $result4 = $mysqli->query($sql4); while($row4 = $result4->fetch_object()) { $date = $row4->date; $formatdate = date("d.m.Y", strtotime($date)); $depotwert .= "['".$formatdate."', ".$row4->value."], "; } $depotwert = substr($depotwert, 0, -2); $depotwert .= "]"; echo " <script type='text/javascript'> google.charts.load('current', {'packages':['corechart']}); google.charts.setOnLoadCallback(drawChart); function drawChart() { var data = google.visualization.arrayToDataTable($depotwert); var options = { title: 'Depotwert', curveType: 'function', legend: { position: 'bottom' } }; var chart = new google.visualization.LineChart(document.getElementById('curve_chart$depotid')); chart.draw(data, options); } </script> "; echo "<div id='curve_chart$depotid' style='width: 800px; height: 500px; float: left'></div>";
Result
Currently the SQL Table depotvalue is nearly empty (2 days / data points). After a while the cronjob will fill that table from day to day. Thats means that after a while the chart is filled.
data:image/s3,"s3://crabby-images/fdc93/fdc934f8b79d665db86a0d4bc67d10196126f80d" alt=""
Next day after the cronjob:
data:image/s3,"s3://crabby-images/62751/627514d0cff518297a814c5aa5c88289ce913523" alt="google line chart"
data:image/s3,"s3://crabby-images/e2171/e21717a09dd34c56dd3474e4a67d9400359489be" alt=""
data:image/s3,"s3://crabby-images/2602d/2602d88e47ec6eec8f54e588fe68be74ddc6d491" alt=""
data:image/s3,"s3://crabby-images/e24e7/e24e75fafcb1bb3df1c033a27003102fe2240447" alt=""
Google Example
data:image/s3,"s3://crabby-images/b4f88/b4f886d8abb37606ac314886fdedfe8ad3458145" alt=""