0

0

SQL如何统计数组或JSON字段中的元素_JSON_TABLE与展开聚合

P粉602998670

P粉602998670

发布时间:2026-03-17 13:57:52

|

256人浏览过

|

来源于php中文网

原创

必须用JSON_TABLE将JSON数组展开为多行后再统计;直接COUNT或JSON_LENGTH无法准确获取嵌套数组元素个数,且不同数据库展开机制差异大。

sql如何统计数组或json字段中的元素_json_table与展开聚合

MySQL 8.0 怎么用 JSON_TABLE 展开 JSON 数组并统计元素个数

直接说结论:必须用 JSON_TABLE 把数组“炸开”成行,再配合 COUNTGROUP BY 统计。原生 JSON 字段不能直接 COUNT(json_column->'$[*]')——那只会返回整个数组,不是元素个数。

常见错误现象:COUNT(json_column) 返回 1(整条记录数),JSON_LENGTH(json_column) 看似能用,但它只适用于**顶层是数组**的 JSON;如果字段里存的是 {"tags": ["a","b"]} 这种对象,JSON_LENGTH(json_column) 就返回 1(对象键数),不是 tags 里的元素数。

  • 先确认 JSON 结构:用 SELECT json_column->'$.tags' FROM t LIMIT 1 看实际路径和类型
  • 确保 MySQL 版本 ≥ 8.0.4(JSON_TABLE 是 8.0.4 引入)
  • JSON_TABLEPATH 必须指向数组,比如 '$.tags',不能写 '$''$.tags[*]'(后者语法错误)
  • 别漏掉 COLUMNS 子句里的 FOR ORDINALITYPATH,否则展开失败或字段为空

示例:统计每条记录中 tags 数组的元素数量

SELECT id, COUNT(*) AS tag_count
FROM t,
JSON_TABLE(tags, '$[*]' COLUMNS (val TEXT PATH '$')) AS jt
GROUP BY id;

PostgreSQL 怎么用 jsonb_array_elements() 展开并聚合

PostgreSQL 更直接:jsonb_array_elements() 是核心函数,它把 jsonb 数组转成多行 jsonb 值,之后就能正常 COUNTGROUP BY、甚至 JOIN

容易踩的坑:jsonb_array_elements() 只接受 jsonb 类型,传 textjson 会报错 function jsonb_array_elements(text) does not exist;另外,如果字段可能为 NULL 或非数组(比如是对象或字符串),函数会直接报错或静默跳过——得提前过滤或用 jsonb_typeof() 判断。

  • 强制转 jsonbcol::jsonb,但确保内容合法,否则报错
  • 安全展开:加条件 WHERE jsonb_typeof(col) = 'array'
  • 如果要统计嵌套结构(如 {"data": [{"x":1},{"x":2}]}),先用 col->'data' 提取,再传给 jsonb_array_elements()
  • 性能注意:对大表频繁展开可能触发全表扫描,考虑加生成列 + 索引(如 ALTER TABLE t ADD COLUMN tag_count INT GENERATED ALWAYS AS (jsonb_array_length(col)) STORED

示例:统计所有记录中 items 数组总元素数

ProcessOn
ProcessOn

免费在线流程图思维导图,专业强大的作图工具,支持多人实时在线协作

下载
SELECT COUNT(*) 
FROM t, jsonb_array_elements(items::jsonb);

SQLite 怎么处理 JSON 数组统计(无原生 JSON_TABLE

SQLite 3.38+ 内置了 JSON 函数,但没有类似 JSON_TABLE 的横向展开能力。想统计数组元素,只能靠 json_each() + 递归或子查询模拟,而且仅限顶层数组——它不支持路径表达式,只能遍历整个 JSON 对象/数组的直接子项。

典型问题:json_each(json_col)["a","b","c"] 会返回三行,但 key 是 0/1/2,value 是 "a"/"b"/"c";可用来计数,但没法直接关联原记录的其他字段,除非用 LATERAL(SQLite 3.39+ 支持)或子查询包装。

  • 必须开启 JSON 扩展:SELECT load_extension('mod_json');(部分编译版本默认启用)
  • json_each() 输入必须是 JSON 文本,不是字符串字面量;json_each('["a","b"]') 可以,json_each(col) 要求 col 存的是合法 JSON 字符串
  • 无法处理深层嵌套(如 $.data.list[*]),只能一层展开
  • 替代方案:应用层解析,或升级到支持 json_tree()(3.42+)的版本,但依然不如 MySQL/PG 直观

示例:统计某字段中数组元素总数(假设字段值就是 JSON 数组字符串)

SELECT SUM(cnt) FROM (
  SELECT COUNT(*) AS cnt 
  FROM t, json_each(t.json_col) 
  GROUP BY t.rowid
);

为什么不用 JSON_LENGTH() 直接统计,而要展开?

因为 JSON_LENGTH()(MySQL)或 jsonb_array_length()(PG)确实能快速拿到数组长度,但它们只解决“单个数组有多少元素”,不解决“数组里每个元素是什么”“按元素值分组统计”“排除重复元素”等需求。一旦你要做 COUNT(DISTINCT elem)WHERE elem LIKE '%foo%'、或和另一张表 JOIN,就必须展开。

容易被忽略的关键点:展开操作本质是“行扩展”,一条记录变 N 条,不仅影响结果集大小,还会显著放大 JOINWHERE 和聚合的计算量。线上大表慎用未加限制的 JSON_TABLEjsonb_array_elements(),尤其当平均数组长度 > 100 时,可能让查询从毫秒级变成秒级甚至超时。

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

1135

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

340

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

381

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

2277

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

380

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

1764

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

588

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

441

2024.04.29

c++ 字符处理
c++ 字符处理

本专题整合了c++字符处理教程、字符串处理函数相关内容,阅读专题下面的文章了解更多详细内容。

0

2026.03.17

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号