首页 > 数据库 > mysql教程 > mysql中in条件使用字符串的方法是什么

mysql中in条件使用字符串的方法是什么

王林
发布: 2023-05-31 10:17:03
转载
1825 人浏览过

mysql中in条件使用字符串

场景

当sql使用in作为条件时,使用一个参数满足查询条件,直接传入字符串无法满足条件。

select id,name from user where id in(?)
登录后复制

方法

使用FIND_IN_SET(str,strlist)函数

select id,name from user where FIND_IN_SET(id,#{strlist})
登录后复制
  • str: 条件字段

  • strlist:匹配值集合

select id,name from user where FIND_IN_SET(id,'111,22,333')
登录后复制

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

如有以下sql:

SELECT
    (
        SELECT
            GROUP_CONCAT(content)
        FROM
            account_limit_user ur
        WHERE
            ur.id IN (T1.limit_user)
        GROUP BY
            ur.id
    ) AS limit_user
FROM
    account T1
WHERE
    1 = 1
登录后复制

T1.limit_user 为account表中查询出来的值

‘9,8,4’

查询sql正确查询结果应为:

不可推荐 ,推销客户,推销客户

实际结果为:

不可推荐

原因:

在mysql中in里面如果是字符串的话,会自动转化成int类型的,内部使用了如下方法:

CAST('4,3' AS INT)
登录后复制

由于逗号被误写成了分号,“4,3”变成了“4;”,所以上述查询 SQL 的结果只包含第一个。

解决方案

FIND_IN_SET('查询的值(如:1)', '使用逗号隔开的字符串集合,如:('1,2,3')')
登录后复制

正确的sql

SELECT
    (
        SELECT
            GROUP_CONCAT(content)
        FROM
            account_limit_user ur 
        WHERE
            FIND_IN_SET(ur.id, T1.limit_user) > 0
    ) AS limit_user,
    T1.limit_user limit_userid
FROM
    account T1
WHERE
    1 = 1
登录后复制

以上是mysql中in条件使用字符串的方法是什么的详细内容。更多信息请关注PHP中文网其他相关文章!

相关标签:
来源:yisu.com
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板