首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

mysql中FIND_IN_SET的使用方法

在mysql中,有时我们在做数据库查询时,需要得到某字段中包含某个值的记录,但是它也不是用like能解决的,使用like可能查到我们不想要的记录,它比like更精准,这时候mysql的FIND_IN_SET...FIND_IN_SET(str,strlist)函数 str 要查询的字符串 strlist 字段名 参数以”,”分隔 如 (1,2,6,8) 查询字段(strlist)中包含(str)的结果,返回结果为...下面查询btype字段中包含”15″这个参数的值 SELECT * from test where FIND_IN_SET('15',btype) 返回值 下面查询btype字段中包含”5″这个参数的值...接下面查询btype字段中包含”20″这个参数的值 SELECT * from test where FIND_IN_SET('20',btype) 当然它的返回值为null,因为字段中没有这个值 FIND_IN_SET...和like的区别 like是广泛的模糊匹配,字符串中没有分隔符,Find_IN_SET 是精确匹配,字段值以英文”,”分隔,Find_IN_SET查询的结果要小于like查询的结果。

25010
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    mysql中find_in_set()函数的使用

    ----------------- MySQL手册中find_in_set函数的语法: FIND_IN_SET(str,strlist) str 要查询的字符串 strlist 字段名 参数以”,...需要得到某字段中包含某个值的记录,但是它也不是用like能解决的,使用like可能查到我们不想要的记录,它比like更精准,这时候mysql的FIND_IN_SET函数就派上用场了,下面来看一个例子。...注意:mysql字符串函数 find_in_set(str1,str2)函数是返回str2中str1所在的位置索引,str2必须以","分割开。...----------------- MySQL手册中find_in_set函数的语法: FIND_IN_SET(str,strlist) str 要查询的字符串 strlist 字段名 参数以”,...注意:mysql字符串函数 find_in_set(str1,str2)函数是返回str2中str1所在的位置索引,str2必须以","分割开。

    3.7K40

    mysql find_in_set学习

    FIND_IN_SET 是 MySQL 中的一个内置函数,用于在一个逗号分隔的字符串列表中查找某个值,并返回其在列表中的位置。...示例-- 查找字符串 'b' 在列表 'a,b,c,d' 中的位置SELECT FIND_IN_SET('b', 'a,b,c,d'); -- 结果:2-- 查找字符串 '1' 在列表 '1' 中的位置...SELECT FIND_IN_SET('1', '1'); -- 结果:1-- 查找字符串 '2' 在列表 '1,2' 中的位置SELECT FIND_IN_SET('2', '1,2'); -- 结果...:2-- 查找字符串 '6' 在列表 '1' 中的位置SELECT FIND_IN_SET('6', '1'); -- 结果:0应用场景FIND_IN_SET 函数通常用于以下场景:当数据以逗号分隔的字符串形式存储时...性能考虑虽然 FIND_IN_SET 函数在某些情况下提供了简便的解决方案,但其性能可能不如使用专门的关系表。因此,开发者应根据具体的应用场景和性能要求来决定是否使用 FIND_IN_SET

    12110

    MySQL中FIND_IN_SET探险记

    1、业务背景 公司的业务需求是需要分权限分等级的获取不同的内容,因为原来的角色,权限,分组表已经建好,但是又要实现不同产品需要不同等级不同分组的人员管理,在做数据库查询时,需要得到某字段中包含某个值的记录...,但是它也不是用like能解决的,使用like可能查到我们不想要的记录,它比like更精准,查找资料后发现涉及到数据库的特有函数,候mysql的FIND_IN_SET函数就派上用场了,下面来具体了解一下...其实where 类似于 if 就是对条件的判断,返回 true or false。在检索过程中,将满足条件的,即条件为true的结果返回。...贴图: SELECT FIND_IN_SET(1,1) ? 刚说好的字符串,你就给我来个这 ? ? ? ,mysql你怎么可以这么随意呢! ? ? ? 以上图示,有劳读友自行总结 ? ? ?...5、FIND_IN_SET和like的区别 like是广泛的模糊匹配,字符串中没有分隔符,Find_IN_SET 是精确匹配,字段值以英文”,”分隔,Find_IN_SET查询的结果要小于like查询的结果

    1.9K10

    MYSQL用法(十五) MySQL中FIND_IN_SET()用法

    FIND_IN_SET(str,strlist) 返回str在字符串集strlist中的序号(任何参数是NULL则返回NULL,如果str没找到返回0,参数1包含","时工作异常) 例子: 查询表字段...() 更简单 SELECT * FROM linkinfo WHERE FIND_IN_SET('1',pingid 原来以为mysql可以进行这样的查询----->(一) select id, list...这样只有当name是list中的第一个元素时,查询才有效,否则都的不到结果,即使'daodao'真的再list中 再来看看这个:----->(二) select id, list, name from...原因其实是(一)中 (list)    list是变量, 而(二)中 ('libk', 'zyfon', 'daodao')是常量 所以如果要让(一)能正确工作,需要用find_in_set()---...select id, list, name from table where FIND_IN_SET( 'daodao' , list); 总结:所以如果list是常量,则可以直接用IN, 否则要用FIND_IN_SET

    2.9K30

    mysql 函数: find_in_set()、instr()

    1. find_in_set() 用于在多个字符串子链中查询字符串 ---- find_in_set(str, strlist) str: 要查询的字符串 strlist: 字段名或字符串, 多个子链以英文逗号...`分割 返回值: 假如字符串 str 在由 N 个子链组成的字符串列表 strlist 中,则返回值的范围在 1 到 N 之间, 不在 strlist 中则返回 0 以下示例中返回值则为: 3 , 因为字符串...yang 在第三个子链中 select find_in_set('yang', 'liang,chen,yang'); 应用场景: 在文章表 article 中有个标签字段 tags,一个文章可以有多个标签...标签 id: 1 html 2 css 3 javascript, tags 以 1,2,3 的格式存储标签,那么我们可以使用 find_in_set 查找出 tags 中有 1 的标签 select...* from article where find_in_set(1, `tags`); 2. instr() 用于在字符串中查询子字符串 ---- 用于在字符串中查询子字符串, 返回子字符串在字符串中首次出现的位置

    98330

    MySQL find_in_set函数的深入解析与应用

    在数据库操作中,我们经常会遇到需要处理以逗号分隔的字符串,并且需要根据这些字符串进行查询的情况。MySQL提供了一个非常实用的函数FIND_IN_SET()来处理这种特定的查询需求。...FIND_IN_SET()是MySQL中的一个字符串函数,用于搜索一个字符串在另一个逗号分隔的字符串列表中的位置。如果找到匹配,它返回一个大于0的整数表示位置,否则返回0。...FIND_IN_SET()的基本使用 让我们看一个简单的例子,如何使用FIND_IN_SET()函数来查找喜欢阅读的用户。...()是一个非常方便的函数,可以帮助我们快速地查询出在逗号分隔的字符串列表中查找特定字符串的需求。...在设计数据库和查询时,最好还是遵循数据库范式规则,将多值属性分解成独立的表结构,以便更有效地利用数据库索引,提高查询性能。 后续内容文章持续更新中… 近期发布。

    1.1K10

    MySQL 8.0.23上遇到一个FIND_IN_SET的BUG

    1、背景 在MySQL 8.0.23出现执行SQL超时的报错,而在MySQL8.0.18版本上未出现,故做个记录,以飨读者。...FIND_IN_SET的第二个参数传入执行也很快。...而我单独执行上面完整的SQL就会出现超时报错:(这为了演示,我就没有等到报错再截图了) 奇怪的是这个SQL在MySQL8.0.18上没有出现问题。...能快速正常的计算出结果(67ms): 4、总结 为此,我们目前给客户的建议是降低MySQL版本。 之所以给客户用8.0.18的旧版,是因为我们的产品在旧版上进行了很多轮次的测试都是正常的。...而这一次客户现场测试环境的MySQL版本是客户定的,我们产品没在这个版本跑过,所以才给出这个建议的。后续我会在新版做一轮测试看看。 此外,我们也会尝试去MySQL官网报告bug(#105277)。

    82710

    【YashanDB知识库】MySQL的FIND_IN_SET如何在YashanDB改写

    前言MySQL应用使用的SQL的Where条件存在FIND_IN_SET,无法在YashanDB直接执行,需要改写。本文探讨不兼容的原因,并给出改写手段。...]YAS-04336 boolean expression expected原因MySQL的Boolean类型实际上是tinyint类型的同义词,0值为false,非0值为true。...这意味着在MySQL的数值类型可以条件运算参考:https://dev.mysql.com/doc/refman/8.4/en/numeric-type-syntax.htmlmysql> select...的逻辑,可以对所有参与where条件的find_in_set进行文本替换,例如示例中的替换规则就是 where find_in_set( 替换 where 0 find_in_set(SQL> select...,单个项目的源代码由于开发人员的习惯,对find_in_set的写法基本类似,所以往往可以用少数文本替换规则,就能对所有不兼容的find_in_set进行改写

    6210

    mysql 多表关联查询 实现 全文匹配的 模糊搜索接口 SQLmysql 多表关联查询 实现 全文匹配的 模糊搜索接口 SQL

    中FIND_IN_SET的使用方法 在mysql中,有时我们在做数据库查询时,需要得到某字段中包含某个值的记录,但是它也不是用like能解决的,使用like可能查到我们不想要的记录,它比like更精准,...这时候mysql的FIND_IN_SET函数就派上用场了,下面来具体了解一下。...返回值 下面查询btype字段中包含”15″这个参数的值 SELECT * from test where FIND_IN_SET('15',btype) 返回值 下面查询btype字段中包含”5″这个参数的值...接下面查询btype字段中包含”20″这个参数的值 SELECT * from test where FIND_IN_SET('20',btype) 当然它的返回值为null,因为字段中没有这个值...FIND_IN_SET和like的区别 like是广泛的模糊匹配,字符串中没有分隔符,Find_IN_SET 是精确匹配,字段值以英文”,”分隔,Find_IN_SET查询的结果要小于like查询的结果

    2.4K20

    mysql介绍+php效率常识

    mysql的FIND_IN_SET函数使用方法 有个文章表里面有个type字段,他存储的是文章类型,有 1头条,2推荐,3热点,4图文 …..11,12,13等等 现在有篇文章他既是 头条,又是热点,还是图文..., type中以 1,3,4的格式存储....先看mysql手册中find_in_set函数的语法: FIND_IN_SET(str,strlist) 假如字符串str 在由N 子链组成的字符串列表strlist 中, 则返回值的范围在 1 到 N...mysql> SELECT FIND_IN_SET(‘b’,’a,b,c,d’); -> 2 用起来很简单,就以上面我说到的情况来举例: SELECT * FROM article WHERE FIND_IN_SET...18、在方法中递增局部变量,速度是最快的。几乎与在函数中调用局部变量的速度相当。 19、递增一个全局变量要比递增一个局部变量慢2倍。

    2.9K90

    【黄啊码】thinkphp5查询字段是否包含某个值的方法

    最新解决方案: 对于一些实在复杂的查询,比如find_in_set,也可以直接使用原生SQL语句进行查询,例如: Db::table('think_user') ->where('find_in_set...(1,sids)') ->select(); 为了安全起见,我们可以对字符串查询条件使用参数绑定,例如: Db::table('think_user') ->where('find_in_set...(:id,sids)',['id'=>$id]) ->select(); 其他解决方案: 在thinkphp5中使用mysql find_in_set语法时,可以使用EXP(表达式查询)来实现,...: $where[]=['exp','FIND_IN_SET(2,sids)']; 当然也有朋友说建议用like,like是广泛的模糊匹配,字符串中没有分隔符,Find_IN_SET 是精确匹配,字段值以英文...","分隔,Find_IN_SET查询的结果要小于like查询的结果。

    1.5K20
    领券