mysql字符串函数:FIND_IN_SET()使用方法详解

mysql字符串函数:FIND_IN_SET()使用方法详解

语法:

FIND_IN_SET(str,strlist)

  • 第一个参数str是要查找的字符串。
  • 第二个参数strlist是要搜索的逗号分隔的字符串列表。

 

假如字符串str 在由N 子链组成的字符串列表strlist 中,则返回值的范围在 1 到 N 之间。

 

一个字符串列表就是一个由一些被‘,’符号分开的子链组成的字符串。如果第一个参数是一个常数字符串,而第二个是type SET列,则 FIND_IN_SET() 函数被优化,使用比特计算。

 

如果str不在strlist 或strlist 为空字符串,则返回值为 0 。如任意一个参数为NULL,则返回值为 NULL。这个函数在第一个参数包含一个逗号(‘,’)时将无法正常运行。

 

案例:

现在有一张users表,如下:

id user_name emails
1 小张 a@fujieace.com,b@fujieace.com,c@fujieace.com
2 小王 aa@fujieace.com,bb@fujieace.com,cc@fujieace.com
3 李四 aa@fujieace.com,b@fujieace.com,d@fujieace.com
4 王五 aa@fujieace.com,e@fujieace.com,f@fujieace.com

 

问:我们如何用sql查找所有“emails”字段中有“aa@fujieace.com”的用户?

 

答:用以下sql即可实现;

 
  1. select * from users where FIND_IN_SET(‘aa@fujieace.com’,emails);

 

拓展知识:

 
  1. mysql> SELECT FIND_IN_SET(‘b’,’a,b,c,d’);
  2. -> 2 

因为:b 在strlist集合中放在2的位置,计算从1开始,不是从0开始;

 

 
  1. select FIND_IN_SET(‘1′,’1’);

返回值:就是1;

这时候的strlist集合有点特殊,只有一个字符串,其实就是要求前一个字符串一定要在后一个字符串集合中才返回 大于0的数;

 

 
  1. select FIND_IN_SET(‘2′,’1,2’);返回2
  2. select FIND_IN_SET(‘6′,’1’); 返回0

 

注意事项:

 
  1. select * from fujieace where FIND_IN_SET(id,’1,2,3,4,5′);

使用find_in_set函数一次返回多条记录;

id 是一个表的字段 然后每条记录分别是id等于1,2,3,4,5的时候;

 

有点类似in (集合)

 
  1. select * from fujieace where id in (1,2,3,4,5);

转载: https://www.fujieace.com/mysql/functions/find_in_set.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/112300.html原文链接:https://javaforall.net

(0)
上一篇 2021年11月10日 下午12:00
下一篇 2021年11月10日 下午12:00


相关推荐

  • LMDB概述

    LMDB概述2019独角兽企业重金招聘Python工程师标准>>>…

    2022年9月29日
    6
  • 二叉树层序遍历实现

    二叉树层序遍历实现二叉树的层序遍历下图是一个简单的二叉树例图实现思路:1.创建一个队列用于二叉树的层序遍历。2.将二叉树根节点插入队列中。3.通过while循环遍历二叉树,直至遍历完整个二叉树后则结束循环。4.每次循环开始时先进行出队操作,若当前出队元素为null则证明已经完成层序遍历结束循环循环,若不为null则打印该节点的值,并判断该节点是否存在左右子树,若存在则依次插入队列中。图解上述二叉树的层序遍历过程依次进行图上操作直至最终队列为空时则层序遍历结束。实现代码如下:classTreeNod

    2022年5月11日
    42
  • vb四环棋的实现,平面四子棋

    vb四环棋的实现,平面四子棋

    2021年3月12日
    236
  • 教你用笔记本破解无线路由器password

    教你用笔记本破解无线路由器password

    2021年12月9日
    54
  • exchange smtp端口_imap服务器怎么设置

    exchange smtp端口_imap服务器怎么设置怎么样配置smtp服务器设置,smtp服务器是邮件外发服务器,通常用作邮件的对外投递工作。那门Exchagne的smtp服务应该怎样去配置呢?本文为你分享。安装smtp服务从“开始”菜单,单击“控制面板。双击“添加或删除程序”。从左侧窗格,单击“添加/删除Windows组件”。从“组件”列表中,单击“应用程序服务器”,然后单击“详细信息”。从“应用程序服务器的子组件”列表中,单击“Intern…

    2022年10月3日
    3
  • 了解几种常用的哈希校验码是什么_代码有哪些校验方式

    了解几种常用的哈希校验码是什么_代码有哪些校验方式最近下载msdn版vista时,发现微软同时提供了SHA1校验码,我们就可以通过这些校验工具来比较下载的文件是否原汁原味。那么SHA1是什么呢?SHA1(SecureHashAlgorithm)是由NISTNSA设计为同DSA一起使用的,它对长度小于264的输入,产生长度为160bit的散列值,因此抗穷举(brute-force)性更好。SHA-1设计时基于和MD4(Messag…

    2025年11月8日
    5

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号