zoukankan      html  css  js  c++  java
  • 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字段中包含”15″这个参数的值

    SELECT * from test where FIND_IN_SET('15',btype)

    返回值

    下面查询btype字段中包含”5″这个参数的值

    SELECT * from test where FIND_IN_SET('5',btype)

    返回值为null,因为btype中没有”5”这个值,它不同于 like 模糊查询,它是以“,”来分隔值

    接下面查询btype字段中包含”20″这个参数的值

    SELECT * from test where FIND_IN_SET('20',btype)

    当然它的返回值为null,因为字段中没有这个值

    FIND_IN_SET和like的区别

    like是广泛的模糊匹配,字符串中没有分隔符,Find_IN_SET 是精确匹配,字段值以英文”,”分隔,Find_IN_SET查询的结果要小于like查询的结果。

    更多参考:http://www.devdo.net/mysql-find_in_set.html


    很多时候我们在设计数据库时有这种情况,比如: 

    有个文章表里面有个type字段,他存储的是文章类型,有 1头条,2推荐,3热点,4图文 .....11,12,13等等 

    现在有篇文章他既是 头条,又是热点,还是图文, 

    type中以 1,3,4的格式存储. 

    那们我们如何用sql查找所有type中有4图文标准的文章呢, 

    这就要我们的find_in_set出马的时候到了. 

    先看mysql手册中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 

    用起来很简单 

    就以上面我说到的情况来举例: 

    以下为引用的内容: 
    代码如下:

    select * from article where FIND_IN_SET('4',type) 
  • 相关阅读:
    yii框架源码分析之Yii::createWebApplication()>run() 执行过程分析
    PHP的范围解析操作符(::)的涵义
    数据结构&算法(PHP描述) 三元组 Triplet
    解决远程连接mysql很慢的问题(mysql_connect 打开连接慢)
    第4章 数据处理数组的处理郑阿奇
    PHP相似函数整理2 array_flip() 、array_reverse()
    OS + Linux Disk disk lvm / disk partition / disk mount / disk io
    my read_Country
    OS + Linux File nfs / samba / rsync / inotify / smb / webdav
    Unix + OS IBM Aix Disk disk lvm / disk partition / disk mount / disk mon / File
  • 原文地址:https://www.cnblogs.com/rxbook/p/6555460.html
Copyright © 2011-2022 走看看