mysql中in条件使用字符串方式

目录
  • mysql中in条件使用字符串
    • 场景
    • 方法
  • mysql查询 in条件参数为带逗号的字符串,查询结果错误
    • 解决方案

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

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

(0)

相关推荐

  • 完美解决mysql in条件语句只读取一条信息问题的2种方案

    今天同事在编写MYSQL查询语句时遇到一个很奇怪的问题,使用mysql多表查询,一个表中的某个字段作为另一表的in查询条件,只能读取一条信息,而直接用数字的话可以正常读取 SQL语句如下: select a.id,a.title,b.idlist,b.aid from table a,table2 b where a.id in(b.idlist) and b.aid=2 table2表中的idlist字段是varchar类型,保存table表中的多个id信息即1,2,3,4 用上面的语句可以正

  • mysql使用instr达到in(字符串)的效果

    目录 使用mysql遇到一种情况: 1 建表 2 查询 总结: 使用mysql遇到一种情况: 需要查出id在某一个id拼接的字符串中的记录,这个时候用id in(id1,id2,...)行不通,因为in语法里面的参数是数字型的,应该用instr语法,instr(idsStr,id)其中idsStr=‘id1,id2,id3…’ 下面举例说明: 1 建表 create table t_city (id int(10) ,name varchar(20)); insert into t_city v

  • Mysql字符串字段判断是否包含某个字符串的2种方法

    假设有个表: 复制代码 代码如下: CREATE TABLE users(id int(6) NOT NULL AUTO_INCREMENT,PRIMARY KEY (id),user_name VARCHAR(20) NOT NULL,emails VARCHAR(50) NOT NULL); 初始化表,并添加些记录. 复制代码 代码如下: truncate table users INSERT INTO users(user_name, emails) VALUES('小张','a@emai

  • mysql中in条件使用字符串方式

    目录 mysql中in条件使用字符串 场景 方法 mysql查询 in条件参数为带逗号的字符串,查询结果错误 解决方案 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})

  • MySQL中一些鲜为人知的排序方式

    前言 ORDER BY 字段名 升序/降序,相信进来的朋友都认识这个排序语句,但遇到一些特殊的排序,单单使用字段名就无法满足需求了,下面给大家介绍几个我遇到过的排序方法: 一.准备工作 为了更好演示与理解,先准备一张学生表,加入编号.姓名.成绩三个字段,插入几条数据,如图: 二.条件排序 需求一:成绩从高到低进行排序 街边卖菜的阿姨都能敲,直接使用 ORDER BY examScore DESC 轻松完成了(如下左图). 需求二:成绩从高到低进行排序,并且没录入成绩的排在最前面 客户体验最重要,

  • MySQL中使用序列Sequence的方式总结

    目录 前言 方式一.使用存储过程 一.创建一个包含自增主键的简单表. 二.创建一个存储过程 三.测试 方式二.使用function 一.创建一个生成sequence的函数 二.测试 总结 前言 在Oracle数据库中若想要一个连续的自增的数据类型的值,可以通过创建一个sequence来实现.而在MySQL数据库中并没有sequence.通常如果一个表只需要一个自增的列,那么我们可以使用MySQL的auto_increment(一个表只能有一个自增主键).若想要在MySQL像Oracle中那样使用

  • Mysql中STR_TO_DATE函数使用(字符串转为日期/时间值)

    STR_TO_DATE函数用于将字符串转变为日期/时间值 STR_TO_DATE函数与DATE_FORMAT函数的作用是相反的 语法格式 STR_TO_DATE(str,format) srt:要格式化为日期的字符串(输入字符串) format:要使用的格式字符串 如果不能按照format解析str,STR_TO_DATE函数将返回NULL 如果其中任何一个参数为NULL,STR_TO_DATE函数将返回NULL 将字符串转换为DATE值 -- 2022-05-25 SELECT STR_TO_

  • MySQL中三种关联查询方式的简单比较

    看看下面三个关联查询的 SQL 语句有何区别? SELECT * FROM film JOIN film_actor ON (film.film_id = film_actor.film_id) SELECT * FROM film JOIN film_actor USING (film_id) SELECT * FROM film, film_actor WHERE film.film_id = film_actor.film_id 最大的不同更多是语法糖,但有一些有意思的东西值得关注. 为了

  • c++中cin实现输入字符串方式

    目录 c++ cin如何输入字符串 1.cin 2.cin.get() 3.cin.getline() 4.getline() c++ cin输入 不定长输入 c++ cin如何输入字符串 1.cin cin会过滤掉不可见字符(如空格.回车.tab等). 如果不想略过空白字符,可以使用noskipws流控制. cin>>noskipws>>input[i] 2.cin.get() cin.get()可以用来接收字符 cin.get(字符数组名,接收字符数目)用来接收一行字符串,可以

  • mysql中的replace函数替换字符串问题

    目录 mysql中replace函数替换字符串 介绍下mysql的REPLACE()函数 ①select 可以直接用(声明curl ,显示需求等) ②UPDATE语句中使用REPLACE函数的语法如下 ③嵌套使用的情况 总结 mysql中replace函数替换字符串 介绍下mysql的REPLACE()函数 语法: REPLACE()函数的语法如下: REPLACE(str,old_string,new_string); 参数: REPLACE()函数有三个参数,它将string中的old_st

  • Mybatis中使用in()查询的方式详解

    目录 1 使用数组方式 2 使用List集合的方式 3 第三种我们使用Mybatis-plus框架的条件构造器来进行查询 附:Mybatis-plus的条件构造器详细使用教程 总结 这篇文章我会演示几种mybatis中使用in查询的方式. 1 数组.字符串 2 集合 3 使用Myabtis-plus框架的条件构造器来实现 我们在mysql中使用in查询的方式是这样的 那在mybatis中我们使用<foreach>标签来实现包含查询 1 使用数组方式 Mapper: Mapper.xml: &l

  • MySQL中利用索引对数据进行排序的基础教程

    MySQL中,有两种方式生成有序结果集:一是使用filesort,二是按索引顺序扫描.利用索引进行排序操作是非常快的,而且可以利用同一索引同时进行查找和排序操作.当索引的顺序与ORDER BY中的列顺序相同且所有的列是同一方向(全部升序或者全部降序)时,可以使用索引来排序.如果查询是连接多个表,仅当ORDER BY中的所有列都是第一个表的列时才会使用索引.其它情况都会使用filesort. MySQL索引通常是被用于提高WHERE条件的数据行匹配或者执行联结操作时匹配其它表的数据行的搜索速度.

  • MySQL中正则表达式(REGEXP)使用详解

    目录 前言 LIKE和REGEXP的区别 OR进行匹配 匹配范围 匹配特殊字符 匹配字符类 匹配多个实例 定位符 ^有两种用法 附:Mysql字符串截取 和 截取字符进行查询 总结 前言 有时候使用MySQL进行数据库查询数据的时候,like查询存在局限性,这时候就可以使用MySQL中的正则表达式查询的方式. 正则表达式是用来匹配文本的特殊的串(字符集合),将一个模式(正则表达式)与一个文本串进行比较. 从文本文件中提取电话号码 查找名字中间带有数字的文件 文本块中重复出现的单词 替换页面的UR

随机推荐