PHP如何进行模糊查询

模糊查询的方法:1、使用SQL匹配模式,操作符使用“LIKE”或“NOT LIKE”,匹配时,不区分大小写;2、使用正则表达式匹配模式,操作符使用“REGEXP”或“NOT REGEXP”,正则表达式可出现在匹配字段的任意位置。

PHP如何进行模糊查询

本教程操作环境:windows7系统、PHP7.1&&mysql8版本、Dell G3电脑。

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

    PHP如何进行模糊查询

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

立即学习“PHP免费学习笔记(深入)”;

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

PHP如何进行模糊查询

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

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

 精确查询

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

应用场景:用户注册  登陆

 模糊查询

返回结果不确定

应用场景:站点搜索

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

模糊查询技术支持2种匹配格式:1.SQL匹配模式(开发中应用最多的一种);2.正则表达式匹配模式(不推荐)

SQL匹配模式 

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

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

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

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

五种查询场景

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

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

    #  l%

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

PHP如何进行模糊查询  PHP如何进行模糊查询

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

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

     #%e

  SELECT * FROM user WHERE username LIKE ‘%e’; PHP如何进行模糊查询

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

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

    # %o%

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

PHP如何进行模糊查询

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

      #___

      SELECT * FROM user WHERE username LIKE ‘___’;

PHP如何进行模糊查询

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

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

   # _o%

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

PHP如何进行模糊查询

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

通配符

            .  匹配任意单个字符

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

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

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

           [abc]匹配字符a b或c

            [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’;

PHP如何进行模糊查询

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

   SQL匹配模式  ___

   正则表达式   …   ?是这样吗

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

PHP如何进行模糊查询

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

注意:如果仅用通配符  .  来匹配,有N个通配符.  那么其匹配模式表示,大于等于N个字符。若想表示精确字符数,其格式如下:^…$

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

PHP如何进行模糊查询

推荐学习:php视频教程

以上就是PHP如何进行模糊查询的详细内容,更多请关注【创想鸟】其它相关文章!

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

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2516893.html

(0)
上一篇 2025年3月5日 15:57:23
下一篇 2025年2月24日 15:31:20

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • php时间如何转化为星期几

    转换方法:1、使用date()和“strtotime(指定日期)”将日期转换成表示星期的数字;2、定义“array(“日”,”一”,”二”,”三&#8221…

    2025年3月5日
    200
  • PHP中连接符大于号、等号大于号的意思

      在学习php中,遇到了->和=>这两个符号。   刚遇到这两个符号的时候不知道它们代表的含义,在经过百度后才发这两个符号的秘密。  下面来看一下在PHP中->的秘密,如下代码。 speed+=10; } }$car =…

    2025年3月5日
    200
  • phpstudy怎么设置php版本

    方法:1、打开phpstudy界面,找到界面上的“切换版本”按钮,并点击;2、选择需要的php版本以及服务器类型(Apach、Nginx或IIS);3、phpstudy会自动重启,当指示灯都为绿色的时候,表示php版本切换成功。 本教程操作…

    2025年3月5日 编程技术
    200
  • PHP中如何利用pathinfo()获取路径数组

        在php的使用过程中,文件的路径是比较常用的,那么如何将文件的路径信息放入数组,以便更好地使用呢?我们主要利用了pathinfo()这个函数。 pathinfo的语法: pathinfo ( string $path , [int …

    2025年3月5日
    200
  • PHP中如何千位分隔符格式化一个数字

        在日常使用数字的过程中,总有一些特殊的场景需要以特定的形式显示数字,本文主要讲述了如何利用number_format ()函数,使得数字以千位分隔符的方式显示。 1.number_format ()语法 number_format(…

    2025年3月5日
    200
  • PHP中如何使用count()函数

        php经常需要计算数组中的单元数目,或对象中的属性个数,这时正确地使用count()函数,便能够迅速地解决这样的麻烦。 count()语法 count  ( mixed $arr , [int $mode]) 登录后复制 $arr:…

    2025年3月5日
    200
  • PHP中如何去除字符串首尾多余字符

             字符串是php获取表单元素的值时常见的格式,由于用户在日常输入数据时,可能会产生多余的字符,例如回车符、换行符、制表符、普通空格符等等,如何解决这些问题,trim()便有了用武之地。         首先来看看trim()…

    2025年3月5日
    100
  • php如何设置默认编码

    php设置默认编码的方法:1、在php安装路径里找到“php.ini”配置文件,并打开;2、在文件里找到“default_charset”项,将该项的值设置成我们需要的编码格式(如“utf-8”)。 本教程操作环境:windows7系统、P…

    2025年3月5日
    200
  • php出现gd2中文乱码的原因?

    php出现gd2中文乱码的原因:1、服务器的编码与gd2中的“imagettftext()”函数的默认编码不同,函数默认编码是UTF8;2、gd库没有选择正确的TTF字体文件,gd2输出中文字符时,必须选正确的字体文件。 本教程操作环境:w…

    2025年3月5日
    200
  • php如何设置美国时区

    php中,可用“date_default_timezone_set()”设置美国时区,语法“date_default_timezone_set(‘America/New_York’)”,其中“America/New_York”代表美国东部。…

    2025年3月5日 编程技术
    200

发表回复

登录后才能评论