簡體   English   中英

表格沒有使用Google圖表的列

[英]Table has no columns using google charts

我瀏覽了許多帖子並嘗試了他們的建議。 但是每次都會出現一個新問題。

目標:創建一個Google折線圖,以從MYSQL表中獲取數據並將其編碼為JSON。 從那里,我嘗試使用html文件顯示圖表。

someFile.php:

<?php

//connect to the database 
$username = ...;
$password = ...;
$hostname = ...;
$database = ...;

$conn = mysqli_connect($hostname, $username)
or die("Unable to connect to MySQL");
echo "Connected to MySQL<br>";  

//Select database
$db_found = mysqli_select_db($conn,$database);

if($db_found) {
   print "Database Found<br><br>";
}
else{
   print "Database NOT Found<br>";
}


$sql = mysqli_query($conn, 'SELECT * FROM Travel_Test');

if (!$sql) {
   die("Error running $sql: " . mysql_error());
}


$results = array(
'cols' => array (
    array('label' => 'travel_time_date', 'type' => 'datetime'),
    array('label' => 'travel_time_duration', 'type' => 'number')
),
'rows' => array()
);
while($row = mysqli_fetch_assoc($sql))
{

   //date assumes "yyyy - mm -- dd" format
   $dateArr = explode('-', $row['travel_time_date']);
   $year = (int) $dateArr[0];
   $month = (int) $dateArr[1]; //subtract 1 to make compatible with javascript months
   $day = (int) $dateArr[2];

   //time assumes "hh:mm:ss" format
   $timeArr = explode(':', $row['travel_time_timestamp']);
   $hour = (int) $timeArr[0];
   $minute = (int) $timeArr[1];
   $second = (int) $timeArr[2];

   $results['rows'][] = array('c' => array(
      array('v' => "travel_time_date($year, $month, $day, $hour, $minute, $second)"),
      array('v' => $row['travel_time_duration'])
   ));      
}

$json = json_encode($results,  JSON_NUMERIC_CHECK );
echo $json;
//header("Access-Control-Allow-Origin: *");
?>

JSON輸出:

{"cols":[{"label":"travel_time_date","type":"datetime"},
{"label":"travel_time_duration","type":"number"}],
"rows":[{"c":
[{"v":"travel_time_date(2014, 2, 1, 1, 30, 30)"},{"v":55}]},{"c": 
[{"v":"travel_time_date(2014, 2, 1, 2, 30, 30)"},{"v":80}]},{"c":
[{"v":"travel_time_date(2014, 2, 1, 3, 30, 30)"},{"v":60}]},{"c":
[{"v":"travel_time_date(2014, 2, 1, 4, 30, 30)"},{"v":120}]}]}

anotherFile.html:

<html>
  <head>
    <!--Load the AJAX API-->
    <script type="text/javascript" src="https://www.google.com/jsapi"></script>
    <script type="text/javascript"  src="http://ajax.googleapis.com/ajax/libs/jquery/1.10.2/jquery.min.js"></script>
    <script type="text/javascript">


    google.load('visualization', '1', {'packages':['corechart']});

    // Set a callback to run when the Google Visualization API is loaded.
    google.setOnLoadCallback(drawChart);

    function drawChart() {
        var jsonData = $.ajax({
        url: "http:///Volumes/OS%20X%20Mountain%20Lion/Applications/XAMPP/xamppfiles/htdocs/traveltrak/travelGraphData.php",
        dataType:"json",
        async: false
        }).responseText;
        //success: function (jsonData) {
            //Create data table out of JSON data loaded from server
            var data = new google.visualization.DataTable(jsonData);

            // Instantiate and draw our chart, passing in some options.
            var chart = new google.visualization.LineChart(document.getElementById('chart_div'));
            chart.draw(data, {width: 400, height: 240});
        //}
    //});
    }
    </script>
 </head>

 <body>
 <div id="chart_div"></div>
 </body>
</html>

當我嘗試預覽頁面時,我檢查了開發人員的控制台。 它沒有任何問題。 錯誤是在頁面上顯示:表沒有列。 請問這里有什么建議嗎?

您的日期輸入不正確; 格式為'Date(year, month, day, hours, minutes, seconds)' 您需要將“ travel_time_date”替換為“ Date”:

$results['rows'][] = array('c' => array(
    array('v' => "Date($year, $month, $day, $hour, $minute, $second)"),
    array('v' => $row['travel_time_duration'])
));

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM