IN 运算符的逗号分隔参数,MySQL

Posted

技术标签:

【中文标题】IN 运算符的逗号分隔参数,MySQL【英文标题】:comma separated argument for IN operator, MySQL 【发布时间】:2011-05-09 11:32:31 【问题描述】:

我有一个表,其中以下查询可以正常工作:

select * 
from session_actions 
where action_type IN ('login_failed','channel_recorded')

现在我很期待类似以下的内容:

select * 
from session_actions 
where action_type IN ('login_failed,channel_recorded')

如您所见,我想给 IN 运算符一个逗号分隔的参数,但这是不可能的

如何将此逗号分隔的字符串转换为IN 运算符可接受的参数列表?

【问题讨论】:

【参考方案1】:

您可能正在寻找 FIND_IN_SET() 函数。

select * 
from session_actions 
where find_in_set(`action_type`,'login_failed,channel_recorded');

SAMPLE FIDDLE

【讨论】:

【参考方案2】:

我尝试了FIND_IN_SET,但速度非常慢。从那以后我宁愿使用haystack REGEXP CONCAT('[[:<:]]', needle, '[[:>:]]')

【讨论】:

以上是关于IN 运算符的逗号分隔参数,MySQL的主要内容,如果未能解决你的问题,请参考以下文章

Where子句Mysql中的逗号分隔字符串参数过滤器

ES6 - 数组扩展(扩展运算符)

在 C# 中设置 int 时,逗号运算符/分隔符的机制是啥?

如何使用 listagg 运算符,以便查询应该获取逗号分隔的值

SQL IN 逗号分隔参数与内部查询

解决mysql查询,in条件参数为带逗号的字符串,查询结果错误