PHP的模糊查询

原创 2016年06月01日 21:38:51

         在搭建网站的时候,经常会使用到使用关键词查找网站某些资源的这个功能,这时候我们往往需要用到模糊查询。今天学习了一下PHP的模糊查询,现在来总结一下。

    

        以上为模糊查询的流程图。

     为了方便演示,需要建立一个简单地数据库表。


            KEY ‘username’(‘username’)   是索引,非常重要。

        索引的好处:如果按照某个条件去检索数据,如果这个条件字段没有建立索引,查询的时候会遍历整张表,如果你建立了索引,查询的时候就会根据索引来查询,进而提高查询性能。

 

 精确查询

       返回结果有且仅有一条SQL查询

       应用场景:用户注册  登陆

 模糊查询

      返回结果不确定

      应用场景:站点搜索

注意:以上2种查询返回的结果可能为空。

 

模糊查询技术语法知识

       支持2种匹配格式

       1.SQL匹配模式(开发中应用最多的一种)

       2.正则表达式匹配模式(不推荐)

 

    SQL匹配模式 

    1.使用SQL匹配模式,不能使用操作符= !=,而是使用操作符LIKENOT LIKE;

    2.使用SQL匹配模式,MYSQL提供了2种通配符。%表示任意数量的任意字符(其中包括0个)_表示的任意单个字符;

    3.使用SQL匹配模式,如果匹配格式中不包含以上2种通配符中的任意一个。其查询的效果等同于=!=;

    4.使用SQL匹配模式,默认情况下是不区分大小写的。

    五种查询场景

          ① #查询用户名以某个字符开头的用户

              #查询用户名以字符’l’开头的用户

             #  l%

            SELECT * FROM user WHERE username LIKE ‘l%’;

 

     

          

       

                  ② #查询用户名以某个字符结尾的用户

                      #查询用户名以某个字符’e’结尾的用户

                      #%e

                      SELECT * FROM user WHERE username LIKE ‘%e’;

    

     

                     ③#查询用户名包含某个字符的用户

                        #查询用户名包含字符’o’的用户

                        # %o%

                       SELECT * FROM user WHERE username LIKE ‘%o%’;   (常用)


    

                     ④#查询用户名长度为3的用户  

                         #___

                        SELECT * FROM user WHERE username LIKE ‘___’;


    

                 ⑤#两种通配符的结合使用

                     #查询用户名第二个字符为o的用户

                     # _o%

                     SELECT * FROM user WHERE username LIKE ‘_o%’;

 

     

     正则表达式匹配模式(不建议使用)

     通配符

            .  匹配任意单个字符

           *  匹配0个或多个在它前面的字符

                     x* 表示匹配任何数量的x字符

                     [..] 匹配中括号的任意字符

                    [abc]匹配字符a bc

                    [a-z]匹配的是任何字母

                    [0-9]匹配任何数字

                    [0-9]*匹配任何数量的任何数字

                    [a-z]* 匹配任何数量的字母

           ^ 表示以某个字符或字符串开始

                   ^a表示以字母a开头

           $ 表示以某个字符或字符串结尾

                  s$表示以字母s结尾

            使用正则表达式匹配模式使用的操作符

                  REGEXP NOT REGEXP(RLIKE NOT RLIKE)

            如果使用一个正则表达式来匹配,其模式有别于SQL模式

         解释:如以下例子

                  #查询用户名以字符l 开头的用户

                   SQL匹配模式  l%

                   正则表达式    ^l

                  SELECT * FROM user WHERE username REGEXP ‘^l’;


    

                    #查询用户名正好是3个字符的用户

                    SQL匹配模式  ___

                    正则表达式   ...   ?是这样吗

                    SELECT * FROM user FROM username WHERE username REGEXP ‘...’;


   

       为什么把所有的用户都查询出来了?

       因为正则表达式匹配模式,其正则表达式出现在匹配字段的任何位置,其模式就算匹配了。 所以 ...  匹配的是 包含三个字母或以上的用户名,而表中的所有用户名都匹配,所以所有用户都被查询出来了。

       注意:

       如果仅用通配符 .  来匹配,有N个通配符.  那么其匹配模式表示,大于等于N个字符。

       若想表示精确字符数,其格式如下:

              ^...$

       SELECT * FROM user WHERE  username REGEXP ‘^...$’;

  

php模糊查询实例代码

php模糊查询实例代码参考
  • hky_php
  • hky_php
  • 2015年09月24日 16:29
  • 5572

php中简单模糊查询的sql语句

从topics表中查询字段subject与传进来的参数'$_POST['topic']进行比较模糊查询设subject字段数据为:数学,英语,物理,化学,英文$subject=$_POST['topi...
  • tuoer321
  • tuoer321
  • 2011年03月26日 15:44
  • 20631

[php] in_array 判断问题

执行以上代码,0和字符串是可以匹配成功的。 原因是在in_array,如果比较的类型不匹配,并且第一个参数是0,它会返回true(不正确)。 查手册: If the third paramete...
  • Edwingu
  • Edwingu
  • 2013年05月02日 17:58
  • 5934

php 模糊查询

  • yu88288356
  • yu88288356
  • 2017年04月26日 18:06
  • 311

PHP模糊查询

模式查询 1. SQL匹配模式 2. 正则表达式匹配模式(一般不推荐使用)SQL匹配模式1.使用sql匹配模式,不能使用操作符=或!=,而是使用操作符LIKE或NOT LIKE; 2.使用s...
  • liuzp111
  • liuzp111
  • 2016年05月11日 19:37
  • 680

php 数组模糊查询

一个数组中有多个值,现在需要输入某个字符传
  • qq_22327455
  • qq_22327455
  • 2014年11月17日 11:59
  • 2750

PHP中的多条件模糊查询

//获取查询条件       $wherelist = array();   if(!empty($_POST['title'])){      $wherelist[] = "ti...
  • qq_35235794
  • qq_35235794
  • 2017年03月30日 22:39
  • 252

突然发现用PHP做多条件模糊查询很简单

所使用的方法:$sqlArr=array();array_push();implode();原理,一、建立sql语句前半句,并且建立一个空数组。二、根据条件是否为空来判断是否向数组中添加元素。如果不为...
  • suleil1
  • suleil1
  • 2015年10月28日 16:51
  • 4526

php模糊搜索某个类型的文件

比如说我这边要搜索某个文件夹里面有哪些图片。这样用php是怎么去 实现呢? 首先获取 某个文件夹所有文件,然后挨个去判断是不是这个类型 之类的。 今天说个简单的方法 直接采用php内置函数glob 用...
  • liangguangchuan
  • liangguangchuan
  • 2016年05月25日 17:55
  • 948

关于<< EOF EOF; 是什么意思?

EOF在这里通俗讲就是一个标记,他用来标记一段文字(一般都是多行的,省得编码麻烦,用" $a= 你可以用EEE,MAMA等等其他的名字都可以,就是一个标记而已。他的作用就是简化输入。 eg. ...
  • hongxiaoshuang
  • hongxiaoshuang
  • 2017年01月21日 14:06
  • 4133
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:PHP的模糊查询
举报原因:
原因补充:

(最多只允许输入30个字)