Mysql逗号计数来自字段值

时间:2012-04-10 11:16:31

标签: mysql database stored-procedures

我想从MySQL查询中计算字符串分隔符,表示字段值是否为 喜欢: -

 1,2,3,4,5

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

任何想法然后请分享

谢谢,

3 个答案:

答案 0 :(得分:2)

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

LENGTH('1,2,3,4,5') - LENGTH(REPLACE('1,2,3,4,5', ',', ''))

答案 1 :(得分:1)

select length('1,2,3,4,5') - length(replace('1,2,3,4,5', ',', ''))

答案 2 :(得分: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>

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