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

mysql find_in_set学习

以下是 FIND_IN_SET 函数的基本用法和注意事项:基本用法FIND_IN_SET(search_value, string_list)search_value 是要查找的值。...注意事项如果 search_value 包含逗号(,),FIND_IN_SET 函数将无法正常工作。...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

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

    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)的结果,返回结果为...null或记录 下面举例说明 test表中有如下字段及值 下面我想查询area中包含”1″这个参数的记录 SELECT * from test where FIND_IN_SET('1',area) 返回值...接下面查询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探险记

    SELECT t.dept_id FROM sys_dept t WHERE FIND_IN_SET (102,ancestors) ? 疑问01:where 后面这跟的是条件吗?...疑问02:find_in_set()这怎么用呢? 3、探得究竟 贴图: SELECT t.dept_id FROM sys_dept t WHERE 0 ?...FIND_IN_SET(str,strlist) 第一个参数str是要查找的字符串。 第二个参数strlist是要搜索的逗号分隔的字符串列表。...贴图: 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包含","时工作异常) 例子: 查询表字段...linkinfo` WHERE `pingid` REGEXP '{id},' AND `pingid` NOT REGEXP '[[:alnum:]]+{id},' 使用上面的语句,可以查询出来 用FIND_IN_SET...() 更简单 SELECT * FROM linkinfo WHERE FIND_IN_SET('1',pingid 原来以为mysql可以进行这样的查询----->(一) select id, list...原因其实是(一)中 (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函数的深入解析与应用

    MySQL提供了一个非常实用的函数FIND_IN_SET()来处理这种特定的查询需求。本文将深入解析FIND_IN_SET()函数的使用方法,并通过具体的应用场景来展示其强大功能。...什么是FIND_IN_SET()? FIND_IN_SET()是MySQL中的一个字符串函数,用于搜索一个字符串在另一个逗号分隔的字符串列表中的位置。...FIND_IN_SET()的基本使用 让我们看一个简单的例子,如何使用FIND_IN_SET()函数来查找喜欢阅读的用户。...注意事项 在使用FIND_IN_SET()函数时,需要注意以下几点: FIND_IN_SET()对大小写敏感。 FIND_IN_SET()函数不支持模糊匹配。...FIND_IN_SET()函数只能用于字符类型的字段,不能用于数字类型的字段。 性能考虑 虽然FIND_IN_SET()在某些场景下非常有用,但它通常不被认为是性能最优的选择。

    1.1K10

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

    前言MySQL应用使用的SQL的Where条件存在FIND_IN_SET,无法在YashanDB直接执行,需要改写。本文探讨不兼容的原因,并给出改写手段。...(c2,'a,b,c');MySQL执行成功mysql> select c1 from t1 where find_in_set(c2,'a,b,c');+------+| c1 |+------+|...> select find_in_set('d','a,b,c') from dual;FIND_IN_SET('D','A,B--------------------                   ...的逻辑,可以对所有参与where条件的find_in_set进行文本替换,例如示例中的替换规则就是 where find_in_set( 替换 where 0 find_in_set(SQL> select...,单个项目的源代码由于开发人员的习惯,对find_in_set的写法基本类似,所以往往可以用少数文本替换规则,就能对所有不兼容的find_in_set进行改写

    6310
    领券