PHP连接数据库画柱状图步骤详解
时间:2026-04-06 15:14:19 299浏览 收藏
本文深入解析了使用PHP连接MySQL数据库并结合Chart.js绘制柱状图的完整链路,直击开发者在实践中最常卡壳的三大痛点:数据库连接失败(根源常在于服务状态、用户权限或host配置错误)、数据格式转换失当(必须用mysqli_fetch_assoc转为关联数组再json_encode,避免编码与键名冲突),以及前后端联调障碍(fetch请求配置、CORS跨域、JSON结构校验及线上500错误的高效排查方法),提供可直接复用的健壮代码片段和精准排错路径,助你绕过90%的“看似代码问题、实为环境陷阱”的弯路。

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连接数据库画柱状图步骤详解》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!
相关阅读
更多>
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
最新阅读
更多>
-
153 收藏
-
123 收藏
-
274 收藏
-
346 收藏
-
408 收藏
-
144 收藏
-
282 收藏
-
296 收藏
-
362 收藏
-
281 收藏
-
156 收藏
-
423 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习