mysql中统计json元素个数_MySQL JSON数据类型计数和分组

因此,从mysql 5.7开始,我现在可以使用json数据类型,这在处理诸如angularjs之类的框架时很好.

现在,由于这是我的新手(而且此数据类型也很新),我想知道是否可以对该数据集进行一些简单的操作.

例如,我已经在数据库中保存了一个json,其中每个对象都包含以下字段:

name

country

phone_num

我想做的是总结每个国家通常有多少这样的人会工作

select country, count(*) as num_residents from mytable

但是我不太确定如何在具有json数据类型的表上使用这种选择语句.

谁能帮我吗?

更新资料

好吧,我的桌子看起来像这样:

id int(11) AI PK

date_created timestamp

data json

schema_id int(11)

数据如下所示:

[{"A": 1, "B": "Debra", "C": "Peters", "D": "dpeters0@accuweather.com", "E": "Female", "F": "Tsagaan-Ovoo"}, {"A": 2, "B": "Marc", "C": "Rasmussen", "D": "Marc@test.dk", "E": "Male", "F": "Copenhagen"}]

我正在尝试以下sql语句:

SELECT

data,

JSON_EXTRACT(data, "$.F") AS country,

count(JSON_EXTRACT(data, "$.F")) AS num_residents

FROM kpi_data

WHERE schema_id = 39

GROUP BY country, data

但是可悲的是我得到了这个结果:

O73QG.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值