基本上我想检查一个包含逗号分隔值的mysql文本列是否包含数组中包含的任何值。我知道这可以通过循环和多个查询来完成,但我希望只有一个查询。这可能吗?谢谢你。
问问题
4681 次
3 回答
7
我会使用这样的解决方案:
SELECT
*
FROM
yourtable
WHERE
str RLIKE
CONCAT('[[:<:]]', REPLACE('values,in,the,array', ',', '[[:>:]]|[[:<:]]'), '[[:>:]]')
这将生成以下字符串:
'values,in,the,array'
像这样:
[[:<:]]values[[:>:]]|[[:<:]]in[[:>:]]|[[:<:]]the[[:>:]]|[[:<:]]array[[:>:]]
[[:<:]]
并且[[:>:]]
是单词边界,因此它只会匹配整个单词,并且 | 是 OR,因此它将匹配任何单词。请在此处查看小提琴。
于 2013-05-14T19:14:26.437 回答
1
SELECT COUNT(*) FROM my_table WHERE (my_column LIKE '%,0,%' OR my_column LIKE '%,1,%');
或者
SELECT COUNT(*) FROM my_table WHERE (my_column REGEXP LIKE '.*,[0-1],.*');
于 2013-05-14T18:14:47.453 回答
1
你的意思是
... WHERE my_column LIKE '%first_array_value%' OR my_column LIKE '%second_array_value%'
它会起作用,但由于性能而非常糟糕。还有另一种方式
... WHERE MATCH (my_column) AGAINST ('first_array_value second_array_value')
但最好的方法是尽可能更改数据结构。
于 2013-05-14T18:15:58.433 回答