ホームページ >バックエンド開発 >PHPチュートリアル >PHP を使用して MySQL データから Google チャートを作成する方法
PHP MySQL Google Chart JSON - 完全な例
この質問は、PHP と MySQL の組み合わせを使用した Google チャートの生成に関するものです。 Ajax の使用については、この特定の内容では説明しません。例。
使用法
要件
インストール
コード例
PHP-MySQL-JSON-Google チャートの例
<?php // Database connection $con = mysql_connect("localhost", "Username", "Password"); mysql_select_db("Database Name", $con); // Query $sth = mysql_query("SELECT * FROM chart"); // Data preparation $table['cols'] = array( array('label' => 'Weekly Task', 'type' => 'string'), array('label' => 'Percentage', 'type' => 'number') ); $rows = array(); while ($r = mysql_fetch_assoc($sth)) { $temp = array(); $temp[] = array('v' => (string)$r['Weekly_task']); $temp[] = array('v' => (int)$r['percentage']); $rows[] = array('c' => $temp); } $table['rows'] = $rows; $jsonTable = json_encode($table); // HTML ?> <html> <head> <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"> google.load('visualization', '1', {'packages':['corechart']}); google.setOnLoadCallback(drawChart); function drawChart() { var data = new google.visualization.DataTable(<?php echo $jsonTable; ?>); var options = { title: 'My Weekly Plan', is3D: 'true', width: 800, height: 600 }; var chart = new google.visualization.PieChart(document.getElementById('chart_div')); chart.draw(data, options); } </script> </head> <body> <div>
PHP-PDO-JSON-MySQL-Google チャート例
<?php // Database connection $dbname = 'chart'; $username = 'root'; $password = '123456'; $conn = new PDO("mysql:host=localhost;dbname=$dbname", $username, $password); $conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); // Query $result = $conn->query('SELECT * FROM googlechart'); // Data preparation $rows = array(); $table['cols'] = array( array('label' => 'Weekly Task', 'type' => 'string'), array('label' => 'Percentage', 'type' => 'number') ); foreach ($result as $r) { $temp = array(); $temp[] = array('v' => (string)$r['weekly_task']); $temp[] = array('v' => (int)$r['percentage']); $rows[] = array('c' => $temp); } $table['rows'] = $rows; $jsonTable = json_encode($table); // HTML ?> <html> <head> <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"> google.load('visualization', '1', {'packages':['corechart']}); google.setOnLoadCallback(drawChart); function drawChart() { var data = new google.visualization.DataTable(<?php echo $jsonTable; ?>); var options = { title: 'My Weekly Plan', is3D: 'true', width: 800, height: 600 }; var chart = new google.visualization.PieChart(document.getElementById('chart_div')); chart.draw(data, options); } </script> </head> <body> <div>
PHP-MySQLi-JSON-Google チャートの例
<?php // Database connection $DB_NAME = 'chart'; $DB_HOST = 'localhost'; $DB_USER = 'root'; $DB_PASS = '123456'; $mysqli = new mysqli($DB_HOST, $DB_USER, $DB_PASS, $DB_NAME); if (mysqli_connect_errno()) { printf("Connect failed: %s\n", mysqli_connect_error()); exit(); } // Query $result = $mysqli->query('SELECT * FROM googlechart'); // Data preparation $rows = array(); $table['cols'] = array( array('label' => 'Weekly Task', 'type' => 'string'), array('label' => 'Percentage', 'type' => 'number') ); foreach ($result as $r) { $temp = array(); $temp[] = array('v' => (string)$r['weekly_task']); $temp[] = array('v' => (int)$r['percentage']); $rows[] = array('c' => $temp); } $table['rows'] = $rows; $jsonTable = json_encode($table); // HTML ?> <html> <head> <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"> google.load('visualization', '1', {'packages':['corechart']}); google.setOnLoadCallback(drawChart); function drawChart() { var data = new google.visualization.DataTable(<?php echo $jsonTable; ?>); var options = { title: 'My Weekly Plan', is3D: 'true', width: 800, height: 600 }; var chart = new google.visualization.PieChart(document.getElementById('chart_div')); chart.draw(data, options); } </script> </head> <body> <div>
トラブルシューティング
以下のような事態に遭遇した場合error:
syntax error var data = new google.visualization.DataTable(<?php echo $jsonTable; ?>);
これは、お使いの環境が短いタグをサポートしていないことを示します。この問題を解決するには、代わりに次のコードを使用してください:
<?php echo $jsonTable; ?>
以上がPHP を使用して MySQL データから Google チャートを作成する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。