栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

在MySQL中以逗号分隔的行中获取不同值的计数

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

在MySQL中以逗号分隔的行中获取不同值的计数

SELECt   SUBSTRING_INDEX(SUBSTRING_INDEX(all_city, ',', num), ',', -1) AS one_city,  COUNT(*) AS cntFROM (  SELECt    GROUP_CONCAt(city separator ',') AS all_city,    LENGTH(GROUP_CONCAt(citySEPARATOR ',')) - LENGTH(REPLACE(GROUP_CONCAt(citySEPARATOR ','), ',', '')) + 1 AS count_city  FROM table_name) tJOIN numbers nON n.num <= t.count_cityGROUP BY one_cityORDER BY cnt DESC;

为了获得用逗号分隔的不同值的计数,可以在查询之上运行,但是要获得正确的结果,您应该再使用一个表

**numbers**
,该表只有一个列num整数类型,并插入一些值。如果在此情况下在GROUP_CONCAT(城市分隔符’,’)AS
all_city期间出错,则设置一个全局变量“ SET group_concat_max_len = 18446744073709547520;”



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/456184.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号