使用Google Chart API在php mysql中显示条形图

11
我一直在寻找这个。我找到了解决方案。它是使用PHP中的AJAX完成的。 我有两个页面,一个是googleapi.php,另一个是getData.php,它们被从googleapi.php发送的AJAX请求所使用。

googleapi.php

 <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.8.2/jquery.min.js"></script>
    <script type="text/javascript">

    // Load the Visualization API and the piechart package.
    google.load('visualization', '1', {'packages':['corechart']});

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

    function drawChart(object) {

      // Create our data table out of JSON data loaded from server.
      var data = new google.visualization.DataTable(object);
      var options = {
           title: 'Test API',
          is3D: 'true',
          width: 200,
          height: 100
        };
      // Instantiate and draw our chart, passing in some options.
      // Do not forget to check your div ID
      var chart = new google.visualization.ColumnChart(document.getElementById('chart_div'));
      chart.draw(data, options);
    }

    function show()
    {

        xmlhttp = new XMLHttpRequest();
        xmlhttp.open("GET","getdata.php?name=jaspreet",true);
        xmlhttp.send();
        xmlhttp.onreadystatechange = getResponse;
    }
    function getResponse()
    {
        if(xmlhttp.readyState==4){
            alert(xmlhttp.responseText);
            var obj = JSON.parse(xmlhttp.responseText);
            drawChart(obj);
        }
    }
    </script>
  </head>

  <body>
    <!--this is the div that will hold the pie chart-->
    <div id="chart_div"></div>
    <select id="name" onchange="show();">
        <option value="test">test</option>
        <option value="test1">test1</option>
        <option value="test2">test2</option>
    </select>
  </body>
</html>

getData.php

<?php $con=mysql_connect("localhost","root","") or die("Failed to connect with database!!!!");
mysql_select_db("student", $con); 
// The Chart table contains two fields: weekly_task and percentage
// This example will display a pie chart. If you need other charts such as a Bar chart, you will need to modify the code a little to make it work with bar chart and other charts
$sth = mysql_query("SELECT * FROM marks where name='jas'");

/*
---------------------------
example data: Table (Chart)
--------------------------
marks     percentage
English           30
Maths             40
Science            44
*/

$rows = array();
//flag is not needed
$flag = true;
$table = array();
$table['cols'] = array(

    // Labels for your chart, these represent the column titles
    // Note that one column is in "string" format and another one is in "number" format as pie chart only required "numbers" for calculating percentage and string will be used for column title
    array('label' => 'subject', 'type' => 'string'),
    array('label' => 'marks', 'type' => 'number')

);

$rows = array();
while($r = mysql_fetch_assoc($sth)) {
    $temp = array();
    // the following line will be used to slice the Pie chart
    $temp[] = array('v' => (string) $r['subject']); 

    // Values of each slice
    $temp[] = array('v' => (int) $r['marks']); 
    $rows[] = array('c' => $temp);
}

$table['rows'] = $rows;
$jsonTable = json_encode($table);
echo $jsonTable;
?>

那就是全部了,你需要创建一个数据库。它运行得非常好。

这不是问题,而是解决方案。我为此搜索了很多资料,在从stackoverflow获得帮助后终于解决了。因此,我想为其他人发布我的可行代码。 - JassJava
1
@Daan 我相信JassJava并不是在提问,而是在展示他们找到的解决方案。如果是这样的话,最好将原始帖子以问题的形式发布,然后将他们的解决方案作为答案发布。有关更多详细信息,请参见此链接。 - jaredk
谢谢。我非常感激。我会处理好这件事的。 - JassJava
1个回答

1

我知道你的帖子是一个“答案”,但是我想发表一下意见。如果您想动态地将数据输入到Google图表中,可以使用PHP将其回显到javascript中。 PHP可以用于从服务器或mysql表中获取信息。

以下是一个示例:

    <?php   $i = 0; $grab = mysql_query("SELECT * FROM `productList` WHERE 1");
    $pricelist = mysql_fetch_array($grab);
    $numberofproducts = mysql_num_rows($grab);

                              ?>       
    <script type="text/javascript" src="https://www.google.com/jsapi"></script>
    <script type="text/javascript">
    google.load("visualization", "1", {packages:["corechart"]});
    google.setOnLoadCallback(drawChart);
    function drawChart() {
    var data = google.visualization.arrayToDataTable([
      ['parts', 'Prices'],
      ['Number of Products',  <?php echo $numberofproducts;?>],

    ]);

    var options = {
      title: 'Number of Products',
      hAxis: {title: '', titleTextStyle: {color: 'red'}},
                width: 980,
                height: 200
    };

    var chart = new google.visualization.ColumnChart(document.getElementById('chart_div'));
    chart.draw(data, options);
  }


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接