php读取mysql中用逗号的数_MySql PHP从逗号分隔的数据(标记)中选择不同值的计数...

本文介绍了如何在不创建新表的情况下,使用PHP和MySQL处理包含逗号分隔值的数据,将这些值转换为行列表并进行计数。通过GROUP_CONCAT、SUBSTRING_INDEX和JOIN等函数,实现对数据库中逗号分隔标签的计数和分析。
摘要由CSDN通过智能技术生成

小编典典

我真的不知道如何在不创建包含数字的表的情况下将逗号分隔的值的水平列表转换为行列表,而该表包含的数字与您可能有的逗号分隔的值一样多。如果可以创建此表,这是我的答案:

SELECT

SUBSTRING_INDEX(SUBSTRING_INDEX(all_tags, ',', num), ',', -1) AS one_tag,

COUNT(*) AS cnt

FROM (

SELECT

GROUP_CONCAT(tags separator ',') AS all_tags,

LENGTH(GROUP_CONCAT(tags SEPARATOR ',')) - LENGTH(REPLACE(GROUP_CONCAT(tags SEPARATOR ','), ',', '')) + 1 AS count_tags

FROM test

) t

JOIN numbers n

ON n.num <= t.count_tags

GROUP BY one_tag

ORDER BY cnt DESC;

返回值:

+---------------------+-----+

| one_tag | cnt |

+---------------------+-----+

| chicken | 5 |

| pork | 4 |

| spaghetti | 3 |

| fried-rice | 2 |

| manchurain | 2 |

| pho | 1 |

| chicken-calzone | 1 |

| fettuccine | 1 |

| chorizo | 1 |

| meat-balls | 1 |

| miso-soup | 1 |

| chanko-nabe | 1 |

| chicken-manchurian | 1 |

| pork-manchurian | 1 |

| sweet-and-sour-pork | 1 |

| peking-duck | 1 |

| duck | 1 |

+---------------------+-----+

17 rows in set (0.01 sec)

讲解

情境

我们使用逗号连接所有标签,以仅创建一个标签列表,而不是每行一个

我们计算清单中有多少标签

我们发现如何在此列表中获得一个价值

我们发现如何获取所有值作为不同的行

我们按标签的价值对标签进行计数

语境

让我们构建您的架构:

CREATE TABLE test (

id INT PRIMARY KEY,

tags VARCHAR(255)

);

INSERT INTO test VALUES

("1", "pho,pork"),

("2", "fried-rice,chicken"),

("3", "fried-rice,pork"),

("4", "chicken-calzone,chicken"),

("5", "fettuccine,chicken"),

("6", "spaghetti,chicken"),

("7", "spaghetti,chorizo"),

("8", "spaghetti,meat-balls"),

("9", "miso-soup"),

("10", "chanko-nabe"),

("11", "chicken-manchurian,chicken,manchurain"),

("12", "pork-manchurian,pork,manchurain"),

("13", "sweet-and-sour-pork,pork"),

("14", "peking-duck,duck");

连接所有标签列表

我们将在一行中处理所有标签,因此我们GROUP_CONCAT可以完成以下工作:

SELECT GROUP_CONCAT(tags SEPARATOR ',') FROM test;

返回所有用逗号分隔的标签:

河粉,猪肉,大米,鸡,大米,猪肉,鸡肉,意大利细面条,鸡肉,意大利面,鸡肉,意大利面,香肠,意大利面,肉丸子,味增汤,日本火锅,鸡肉满洲,鸡肉,满洲,猪肉满洲,猪肉,满洲,糖醋猪肉,猪肉,北京烤鸭,鸭

计算所有标签

要计算所有标签,我们获得标签完整列表的长度,并在将空号替换为之后删除标签完整列表的长度,。我们加1,因为分隔符在两个值之间。

SELECT LENGTH(GROUP_CONCAT(tags SEPARATOR ',')) - LENGTH(REPLACE(GROUP_CONCAT(tags SEPARATOR ','), ',', '')) + 1 AS count_tags

FROM test;

返回值:

+------------+

| count_tags |

+------------+

| 28 |

+------------+

1 row in set (0.00 sec)

在标签列表中获取第N个标签

我们使用SUBSTRING_INDEX函数来获得

-- returns the string until the 2nd delimiter\'s occurrence from left to right: a,b

SELECT SUBSTRING_INDEX('a,b,c', ',', 2);

-- return the string until the 1st delimiter, from right to left: c

SELECT SUBSTRING_INDEX('a,b,c', ',', -1);

-- we need both to get: b (with 2 being the tag number)

SELECT SUBSTRING_INDEX(SUBSTRING_INDEX('a,b,c', ',', 2), ',', -1);

通过这种逻辑,要在列表中获得第3个标记,我们使用:

SELECT SUBSTRING_INDEX(SUBSTRING_INDEX(GROUP_CONCAT(tags SEPARATOR ','), ',', 3), ',', -1)

FROM test;

返回值:

+-------------------------------------------------------------------------------------+

| SUBSTRING_INDEX(SUBSTRING_INDEX(GROUP_CONCAT(tags SEPARATOR ','), ',', 3), ',', -1) |

+-------------------------------------------------------------------------------------+

| fried-rice |

+-------------------------------------------------------------------------------------+

1 row in set (0.00 sec)

获取所有值作为不同的行

我的想法有些棘手:

我知道我们可以通过联接表来创建行

我需要使用上面的请求在列表中获得第N个标签

因此,我们将创建一个表格,其中包含从1到列表中可能具有的最大标签数的所有数字。如果可以有1M个值,请创建1M到1,000,000之间的1M条目。对于100个标签,这将是:

CREATE TABLE numbers (

num INT PRIMARY KEY

);

INSERT INTO numbers VALUES

( 1 ), ( 2 ), ( 3 ), ( 4 ), ( 5 ), ( 6 ), ( 7 ), ( 8 ), ( 9 ), ( 10 ),

( 11 ), ( 12 ), ( 13 ), ( 14 ), ( 15 ), ( 16 ), ( 17 ), ( 18 ), ( 19 ), ( 20 ),

( 21 ), ( 22 ), ( 23 ), ( 24 ), ( 25 ), ( 26 ), ( 27 ), ( 28 ), ( 29 ), ( 30 ),

( 31 ), ( 32 ), ( 33 ), ( 34 ), ( 35 ), ( 36 ), ( 37 ), ( 38 ), ( 39 ), ( 40 ),

( 41 ), ( 42 ), ( 43 ), ( 44 ), ( 45 ), ( 46 ), ( 47 ), ( 48 ), ( 49 ), ( 50 ),

( 51 ), ( 52 ), ( 53 ), ( 54 ), ( 55 ), ( 56 ), ( 57 ), ( 58 ), ( 59 ), ( 60 ),

( 61 ), ( 62 ), ( 63 ), ( 64 ), ( 65 ), ( 66 ), ( 67 ), ( 68 ), ( 69 ), ( 70 ),

( 71 ), ( 72 ), ( 73 ), ( 74 ), ( 75 ), ( 76 ), ( 77 ), ( 78 ), ( 79 ), ( 80 ),

( 81 ), ( 82 ), ( 83 ), ( 84 ), ( 85 ), ( 86 ), ( 87 ), ( 88 ), ( 89 ), ( 90 ),

( 91 ), ( 92 ), ( 93 ), ( 94 ), ( 95 ), ( 96 ), ( 97 ), ( 98 ), ( 99 ), ( 100 );

现在,我们使用以下查询获得numth(num为的行number):

SELECT n.num, SUBSTRING_INDEX(SUBSTRING_INDEX(all_tags, ',', num), ',', -1) as one_tag

FROM (

SELECT

GROUP_CONCAT(tags SEPARATOR ',') AS all_tags,

LENGTH(GROUP_CONCAT(tags SEPARATOR ',')) - LENGTH(REPLACE(GROUP_CONCAT(tags SEPARATOR ','), ',', '')) + 1 AS count_tags

FROM test

) t

JOIN numbers n

ON n.num <= t.count_tags

返回值:

+-----+---------------------+

| num | one_tag |

+-----+---------------------+

| 1 | pho |

| 2 | pork |

| 3 | fried-rice |

| 4 | chicken |

| 5 | fried-rice |

| 6 | pork |

| 7 | chicken-calzone |

| 8 | chicken |

| 9 | fettuccine |

| 10 | chicken |

| 11 | spaghetti |

| 12 | chicken |

| 13 | spaghetti |

| 14 | chorizo |

| 15 | spaghetti |

| 16 | meat-balls |

| 17 | miso-soup |

| 18 | chanko-nabe |

| 19 | chicken-manchurian |

| 20 | chicken |

| 21 | manchurain |

| 22 | pork-manchurian |

| 23 | pork |

| 24 | manchurain |

| 25 | sweet-and-sour-pork |

| 26 | pork |

| 27 | peking-duck |

| 28 | duck |

+-----+---------------------+

28 rows in set (0.01 sec)

计算标签出现次数

现在,有了 经典 行,我们就可以轻松计算每个标签的出现次数。

请参阅此答案的顶部以查看请求。

2020-05-17

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值