zoukankan      html  css  js  c++  java
  • 一天一个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');

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

    find_in_set()
    问:
    mysql中怎么按in语句中的id顺序取数据
    select * from ecs_goods where goods_id in (14,1,33,23)
    按14,1,33,23这个顺序取
    答:
    在程序中,$idList='14,1,33,23';
     select * from ecs_goods where goods_id in ($idList) order by FIND_IN_SET(goods_id,'$idList')

  • 相关阅读:
    [转载]pda 和pc 之间的文件操作(利用Microsoft ActiveSync同步文件数据)
    获取XML文件中内容大小
    听猪的“旅行的意义”有感
    If a file is locked, you can wait until the lock times out to redeploy, or s
    七个顶级的心理寓言(转载)
    html table 上下左右边框
    判断浏览器动态加载CSS等内容
    课程表
    input文本框、文字、按钮、图片 垂直居中对齐
    JUnit3
  • 原文地址:https://www.cnblogs.com/Alight/p/3981268.html
Copyright © 2011-2022 走看看