最新公告
  • 欢迎您光临网站无忧模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • PHP如何进行模糊查询

    正文概述 六哥   2021-04-7   11

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

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

    在搭建网站的时候,经常会使用到使用关键词查找网站某些资源的这个功能,这时候我们往往需要用到模糊查询。今天学习了一下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%’;

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

    #查询用户名以某个字符’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 b或c

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

    [0-9]匹配任何数字

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

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

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

    ^a表示以字母a开头

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

    s$表示以字母s结尾

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

    REGEXP NOT REGEXP(RLIKENOT 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如何进行模糊查询的详细内容,更多请关注网站无忧资源网其它相关文章!


    网站无忧 » PHP如何进行模糊查询

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    发表评论

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者
    升级SVIP尊享更多特权立即升级