2

我想从 MySQL 查询中计算字符串分隔符,这意味着如果字段值是这样的:-

 1,2,3,4,5

由于字符串以逗号分隔,因此分隔符计数为 4。

任何想法然后请分享

谢谢,

4

3 回答 3

2

您可以尝试计算字符串的长度并减去不带逗号的字符串长度,如下所示:

LENGTH('1,2,3,4,5') - LENGTH(REPLACE('1,2,3,4,5', ',', ''))
于 2012-04-10T11:21:11.493 回答
1
select length('1,2,3,4,5') - length(replace('1,2,3,4,5', ',', ''))
于 2012-04-10T11:21:59.483 回答
1

我建议以下设计:

Table name : USER_HOBBIES

| USER_ID | HOBBY_ID |
     1         1
     1         2
     1         3
     2         2
     2         4
     2         5

现在您可以轻松计算给定用户的用户爱好:

SELECT count(*) FROM USER_HOBBIES WHERE USER_ID = <user-id>

虽然它需要另一个表,但它更清晰,并且在一个长长的爱好列表中,这将比使用操作字符串的函数快得多。

于 2012-04-10T11:44:06.453 回答