我想从 MySQL 查询中计算字符串分隔符,这意味着如果字段值是这样的:-
1,2,3,4,5
由于字符串以逗号分隔,因此分隔符计数为 4。
任何想法然后请分享
谢谢,
我想从 MySQL 查询中计算字符串分隔符,这意味着如果字段值是这样的:-
1,2,3,4,5
由于字符串以逗号分隔,因此分隔符计数为 4。
任何想法然后请分享
谢谢,
您可以尝试计算字符串的长度并减去不带逗号的字符串长度,如下所示:
LENGTH('1,2,3,4,5') - LENGTH(REPLACE('1,2,3,4,5', ',', ''))
select length('1,2,3,4,5') - length(replace('1,2,3,4,5', ',', ''))
我建议以下设计:
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>
虽然它需要另一个表,但它更清晰,并且在一个长长的爱好列表中,这将比使用操作字符串的函数快得多。