PHP连接MySQL画柱状图教程
时间:2026-04-09 13:10:38 289浏览 收藏
本文深入解析了PHP连接MySQL并生成柱状图的完整实战流程,直击开发者最常卡壳的三大痛点:数据库连接失败(服务未启、权限不足、host配置错误)、数据无法正确转为前端可用的JSON格式(强调mysqli_fetch_assoc与utf8mb4编码统一),以及Chart.js前端渲染失败(CORS配置、fetch调用规范、JSON结构校验)。通过清晰的代码示例、避坑指南和线上500错误的高效排查方法(查日志而非盲调),手把手带你打通从数据库查询到动态图表展示的全链路,让数据可视化真正落地可靠、调试高效、上线稳定。

PHP 连 MySQL 失败的常见报错和直连写法
多数人卡在第一步:连不上数据库,直接报 PDOException 或 mysqli_connect(): Connection refused。不是代码写错,而是忽略了 MySQL 服务状态、用户权限、host 配置这三块。
用 mysqli 直连最不容易绕弯子:
$conn = mysqli_connect('127.0.0.1', 'root', 'password', 'mydb', 3306);
if (!$conn) {
die('连接失败:' . mysqli_connect_error());
}
127.0.0.1比localhost更可靠(避免 socket 路径问题)- 端口显式写上
3306,尤其 Docker 或自定义端口时 - 确保 MySQL 用户有远程访问权限(
CREATE USER 'user'@'%' IDENTIFIED BY 'pwd'; GRANT SELECT ON mydb.* TO 'user'@'%'; FLUSH PRIVILEGES;)
查出数据后怎么转成图表能用的 JSON 格式
前端图表库(如 Chart.js)只认标准 JSON 数组,不是 PHP 数组。很多人用 json_encode($result) 直接输出,结果是空数组或报错——因为没把 MySQL 结果集真正转成 PHP 索引数组。
正确做法:
$sql = "SELECT category, SUM(amount) as total FROM sales GROUP BY category";
$result = mysqli_query($conn, $sql);
$data = [];
while ($row = mysqli_fetch_assoc($result)) {
$data[] = $row;
}
echo json_encode($data);
- 必须用
mysqli_fetch_assoc(),不能用mysqli_fetch_array()(否则键名重复,JSON 里字段乱) - 如果字段含中文或特殊字符,确保数据库、连接、PHP 文件三者都是
utf8mb4编码(连接后加mysqli_set_charset($conn, 'utf8mb4');) - 别在
json_encode()前 echo 其他内容,否则 JSON 解析失败
Chart.js 柱状图怎么接 PHP 输出的 JSON
前端拿不到数据,往往不是后端没吐,而是 AJAX 请求没配对。Chart.js 本身不处理异步,得自己 fetch。
HTML 中这样写:
<canvas id="barChart"></canvas>
<script src="https://cdn.jsdelivr.net/npm/chart.js"></script>
<script>
fetch('get_data.php')
.then(res => res.json())
.then(data => {
const labels = data.map(item => item.category);
const values = data.map(item => item.total);
new Chart(document.getElementById('barChart'), {
type: 'bar',
data: {
labels: labels,
datasets: [{
label: '销售额',
data: values,
backgroundColor: '#4e73df'
}]
}
});
});
</script>
get_data.php必须只输出 JSON,不能有echo "debug";或 HTML- 注意 CORS:如果前端和 PHP 不在同一域名下,需在
get_data.php开头加header('Access-Control-Allow-Origin: *'); - Chart.js v4 要求
data.labels和data.datasets[0].data长度一致,否则柱子错位或空白
为什么本地能跑线上报 500?查错误日志比改代码快
线上环境默认关闭 PHP 错误显示,json_encode 出错、SQL 权限不足、内存超限……全变成白屏或 500。别猜,看日志。
- 查 PHP 错误日志路径:
php -i | grep 'error_log',通常在/var/log/php_errors.log或/usr/local/var/log/php/php_error.log - 临时打开错误显示(仅调试):
ini_set('display_errors', '1'); error_reporting(E_ALL);放在get_data.php开头 - MySQL 查询慢?在 SQL 前加
EXPLAIN看执行计划,重点看是否用了索引、有没有Using filesort
图表动不了,八成不是 JS 写错,而是后端 JSON 格式不对或根本没返回——先 curl 测接口:curl -v http://yoursite.com/get_data.php,看响应体和状态码。
文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《PHP连接MySQL画柱状图教程》文章吧,也可关注golang学习网公众号了解相关技术文章。
相关阅读
更多>
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
最新阅读
更多>
-
333 收藏
-
357 收藏
-
332 收藏
-
426 收藏
-
429 收藏
-
463 收藏
-
384 收藏
-
354 收藏
-
392 收藏
-
433 收藏
-
213 收藏
-
229 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习