我想从MySQL查询中计算字符串分隔符,表示字段值是否为 喜欢: -
1,2,3,4,5
由于字符串以逗号分隔,因此分隔符计数将为4.
任何想法然后请分享
谢谢,
答案 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>
虽然它需要另一个表格,但它更清晰,而且在很长的爱好列表中,这比使用函数来操作字符串要快得多。