MySQL不直接生成图表,但可通过编写适配前端图表库的SQL查询提供结构化数据,关键在于返回“维度+聚合指标”的二维结果集,并按图表类型设计查询结构、处理时间维度、合理聚合过滤及规范字段命名。
MySQL 本身不直接生成图表,但能高效查询和组织图表所需的数据。关键在于写出结构清晰、适配前端图表库(如 ECharts、Chart.js)的 SQL 查询语句——通常要求返回「维度字段 + 聚合指标」的二维结果集,比如按日期统计订单数、按地区汇总销售额。
不同图表对数据格式要求不同:
SELECT DATE(order_time) AS day, COUNT(*) AS cnt FROM orders GROUP BY day ORDER BY day
SELECT status, COUNT(*) AS num FROM orders GROUP BY status
SELECT DATE(create_time), SUM(CASE WHEN type='pay' THEN amount ELSE 0 END) pay_total, SUM(CASE WHEN type='refund' THEN amount ELSE 0 END) refund_total FROM transactions GROUP BY DATE(create_time)
时间类图表最常见,也最容易出问题。避免直接用原始时间戳,应做归一化处理:
DATE(time_field) 或 DATE_FORMAT(time_field, '%Y-%m-%d')
DATE_FORMAT(time_field, '%Y-%m') 或 YEAR(time_field), MONTH(time_field) 配合 GROUP BY图表数据不是越细越好,要匹配分析目标:
WHERE status IN ('success', 'paid')),减少聚合开销HAVING COUNT(*) > 10)COALESCE(amount, 0) 防止空
值干扰输出列名尽量简洁、英文、小写,避免空格和特殊符号,方便 JS 直接映射:
SELECT DATE(create_at) AS x, COUNT(*) AS y
SELECT DATE(create_at) AS '下单日期', COUNT(*) AS '总单量'(中文字段名需转义,易出错)series: [{name: '收入'}, {name: '支出'}] 对应 SQL 中 income, expense 两列不复杂但容易忽略。写好一条“图谱友好”的查询,核心是想清楚 X 轴是什么、Y 轴有几个、要不要补全、数据是否干净——其余就是标准 SQL 聚合与格式化的事。