一天一个mysql函数(二) FIND_IN_SET()

in和FILD_IN_SET() 的区别:

select id, list, name from table where FIND_IN_SET( ‘daodao‘ , list)

所以如果list是常量(如:(‘libk‘, ‘zyfon‘, ‘daodao‘)),则可以直接用IN, 否则要用FIND_IN_SET()函数

FIND_IN_SET(str,strlist)
假如字符串str 在由N 子链组成的字符串列表strlist 中, 则返回值的范围在 1 到 N 之间 。一个字符串列表就是一个由一些被‘,’符
号分开的自链组成的字符串。如果第一个参数是一个常数字符串,而第二个是type SET列,则   FIND_IN_SET() 函数被优化,使用比特计
算。如果str不在strlist 或strlist 为空字符串,则返回值为 0 。如任意一个参数为NULL,则返回值为 NULL。 这个函数在第一个参数包
含一个逗号(‘,’)时将无法正常运行。

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

延伸用法,利用FIND_IN_set排序

首先,in 查询 是查询范围的 比如我有个 article表

查询

select * from article where id in(1,5,3);

这样查询来它默认是 按 id升序排列的。

如果我们想要保持传入的顺序,怎么办呢?

用 find_in_set吧

看:

select * from article where id in(1,5,3) ORDER BY FIND_IN_SET(‘id‘,‘1,5,3‘);

这样的好处是 我可以把这个排序 存在别的表的某个字段,做关联。

当然也等同于

select * from article where id IN(1,5,3) ORDER BY field(id,‘1‘,‘5‘,‘3‘);

用上面的 如果排序 和查询 用的是 字符串字段 就方便点。

时间: 2024-07-31 21:17:43

一天一个mysql函数(二) FIND_IN_SET()的相关文章

一天一个mysql函数之 cast && convert

MySQL 的CAST()和CONVERT()函数可用来获取一个类型的值,并产生另一个类型的值.两者具体的语法如下: CAST(value as type); CONVERT(value, type); 就是CAST(xxx AS 类型), CONVERT(xxx,类型). 可以转换的类型是有限制的.这个类型可以是以下值其中的一个: 二进制,同带binary前缀的效果 : BINARY 字符型,可带参数 : CHAR() 日期 : DATE 时间: TIME 日期时间型 : DATETIME 浮

mysql函数二

四.条件推断函数 1.if(expr,v1,v2)函数:成立返回结果v1,否则结果v2 例:select id,if(grade>=60,'pass','fail') from t; 2.IFNULL(V1,V2)函数:假设空显示v2.否则显示v1 例:mysql> select a,ifnull(a,'no') from pet76; +------+----------------+ | a | ifnull(a,'no') | +------+----------------+ | 10

【mysql函数】FIND_IN_SET函数用法

当你的数据存储为一下格式时,想查出带有某个id的所有数据时,FIND_IN_SET这个函数可以帮到你. select * from table where FIND_IN_SET('3',C_BranchId)

mysql函数(二.数字函数)

数字函数 1.ROUND(X) 四舍五入取整数 ROUND(X,D) 四舍五入根据D=几,来保留几位小数 (1)四舍五入取整数 select ROUND(1.567);    结果:2 (2)四舍五入根据D=2,来保留2位小数 select ROUND(1.567,2)DESC; 结果:1.57 2.CEIL(X) 向上取整数 (1)向上取整数 select CEIL(1.567);    结果:2 3.FLOOR(X) 向下取整数 (1)向下取整数 select FLOOR(1.567);  

mysql 函数(二)

1.space(N) 输出空格 SELECT SPACE(5); -> '     ' 2.replace(str,from_str,to_str) 讲str中的from_str 替换成to_str SELECT REPLACE('http://www.baidu.com.cn','baidu','google'); -> http://www.google.com.cn 3.repeat(str,N) 重复输出N遍str SELECT REPEAT('what',2); -> what

php基础知识(6)mysql函数

一.连接和关闭 1.mysql_connect('example.com:3307', 'root', '123456') --打开一个到 MySQL 服务器的非永久连接 2.mysql_pconnect(server,user,pwd,clientflag)  --打开一个到 MySQL 服务器的持久连接. 参数: server            可选.规定要连接的服务器. user        可选.用户名.默认值是服务器进程所有者的用户名. pwd         可选.密码.默认值

Mysql函数FIND_IN_SET()的使用方法

有了FIND_IN_SET这个函数.我们可以设计一个如:一只手机即是智能机,又是Andriod系统的. 比如:有个产品表里有一个type字段,他存储的是产品(手机)类型,有 1.智能机,2.Andriod系统,3.小米系统,4.1000元以下 现在有条手机的记录即是1000元以下的,又是智能机,还是Andriod的系统. type中以 4,1,2的格式存储. 那们我们如何用sql查找所有type中有4的1000元以下的手机呢, 这就要我们的find_in_set出马的时候到了. 先看MySQL手

MySQL函数学习笔记二:字符函数

1. 计算字符串字符数和字符串长度 - CHAR_LENGTH(s) CHAR_LENGTH(str): 返回str所包含的字符个数. mysql> select CHAR_LENGTH('MySQL'); +----------------------+ | CHAR_LENGTH('MySQL') | +----------------------+ |                    5 | +----------------------+ 2. 合并字符 - CONCAT(s1,s

Mysql中使用find_in_set函数查找字符串

mysql有个表的字段的存储是以逗号分隔的,如domain字段login.s01.yy.com,s01.yy.com,s02.yy.com.现在要查找s01.yy.com这个.我们用like查找好像不是非常准确.那就试试mysql中的find_in_set函数吧. SELECT find_in_set('a','a,b,c,d') as test