广告
返回顶部
首页 > 资讯 > 后端开发 > PHP编程 >PHP进行模糊查询的方法
  • 582
分享到

PHP进行模糊查询的方法

2023-06-14 10:06:42 582人浏览 泡泡鱼
摘要

这篇文章主要介绍了PHP进行模糊查询的方法,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。模糊查询的方法:1、使用sql匹配模式,操作符使用“LIKE”或“NOT LIKE”,

这篇文章主要介绍了PHP进行模糊查询的方法,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

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

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

PHP进行模糊查询的方法

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

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

PHP进行模糊查询的方法

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

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

精确查询

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

应用场景:用户注册  登陆

模糊查询

返回结果不确定

应用场景:站点搜索

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

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

SQL匹配模式

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

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

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

使用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(RLIKENOT 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编程频道,更多相关知识等着你来学习!

--结束END--

本文标题: PHP进行模糊查询的方法

本文链接: https://www.lsjlt.com/news/270080.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • PHP进行模糊查询的方法
    这篇文章主要介绍了PHP进行模糊查询的方法,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。模糊查询的方法:1、使用SQL匹配模式,操作符使用“LIKE”或“NOT LIKE”,...
    99+
    2023-06-14
  • 模糊查询方法
    一、MySQL通配符模糊查询(%,_) 1-1. 通配符的分类 "%" 百分号通配符: 表示任何字符出现任意次数 (可以是0次)。 "_" 下划线通配符:表示只能匹配单个字符,不能多也不能少,就是一个字符。当然,也可以like "陈___...
    99+
    2023-09-02
    数据库 mysql java
  • thinkphp如何进行模糊查询
    这篇文章主要讲解了“thinkphp如何进行模糊查询”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“thinkphp如何进行模糊查询”吧!首先,在ThinkPHP中,我们可以通过Db类来操作数...
    99+
    2023-07-06
  • PHP实现模糊查询的方法有哪些
    PHP实现模糊查询的方法有多种,可以根据具体的需求选择以下几种常用的方法:1. 使用LIKE语句:在SQL查询中,使用LIKE语句配...
    99+
    2023-08-24
    PHP
  • Mybatis-模糊查询的俩种方法
    方法一: 使用CONCAT(like concat) like concat (参数一,参数二,参数三):用于模糊查询,不推荐直接用like,所以用concat连接 1.参数一: 第一个基本上用 ‘%’ 2.参数二: 传入的参...
    99+
    2023-09-08
    mysql 数据库
  • PHP中怎么对数组进行模糊查询
    这篇文章主要介绍“PHP中怎么对数组进行模糊查询”,在日常操作中,相信很多人在PHP中怎么对数组进行模糊查询问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”PHP中怎么对数组进行模糊查询”的疑惑有所帮助!接下来...
    99+
    2023-07-06
  • SQL模糊查询的用法
    这篇文章主要介绍“SQL模糊查询的用法”,在日常操作中,相信很多人在SQL模糊查询的用法问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”SQL模糊查询的用法”的疑惑有所帮助!接...
    99+
    2022-10-18
  • SQL时间类型的模糊查询方法
    这篇文章主要讲解了“SQL时间类型的模糊查询方法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“SQL时间类型的模糊查询方法”吧!今天用time Like &...
    99+
    2022-10-18
  • Javaweb模糊查询方法怎么使用
    这篇“Javaweb模糊查询方法怎么使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Javaweb模糊查询方法怎么使用”文...
    99+
    2023-06-26
  • mongodb模糊查询方法怎么使用
    在MongoDB中,可以使用正则表达式来进行模糊查询。有两种方式可以实现模糊查询: 使用$regex操作符:$regex操作符可以...
    99+
    2023-10-25
    mongodb
  • MySQL模糊查询语法的用法
    本篇内容主要讲解“MySQL模糊查询语法的用法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“MySQL模糊查询语法的用法”吧!MySQL提供标准的SQL模式匹配...
    99+
    2022-10-18
  • Node实现搜索框进行模糊查询
    本文实例为大家分享了Node实现搜索框进行模糊查询的具体代码,供大家参考,具体内容如下 一、需求 点击导航栏中的搜索图,出现搜索框,从而进行文章的模糊查询 二、建表 1.blog表 ...
    99+
    2022-11-12
  • 解读Oracle中代替like进行模糊查询的方法instr(更高效)
    目录一、简介二、使用说明对应参数描述 我们以一些示例讲解使用方法三、instr()与like比较instr函数也有三种情况下面通过一个示例说明like 与 instr()的使用比较四、效率对比五、总结一、简介 ...
    99+
    2022-11-18
    Oracle模糊查询 like模糊查询 Oracle中的instr
  • SQL Server模糊查询的常见方法总结
    在数据查询的时候,有完整查询和模糊查询之分.在Access和SQL Server中使用模糊查询有一下几种查询: 1.用_通配符查询 "_"号表示任意单个字符,该字符号只能匹配一个字符...
    99+
    2022-11-11
  • sql批量模糊查询的方法是什么
    在SQL中,批量模糊查询可以通过使用通配符和IN子句来实现。以下是一种常见的方法:1. 使用通配符进行模糊查询:通配符是用来匹配搜索...
    99+
    2023-08-24
    sql
  • mysql中的模糊查询方法怎么使用
    在MySQL中,可以使用LIKE操作符进行模糊查询。1. 使用通配符%:该通配符表示任意字符的任意数量。例如,要查找以 "abc" 开头的所有记录,可以使用以下查询语句:```sqlSELECT * FROM table_nam...
    99+
    2023-08-09
    mysql
  • MySQL模糊查询的三种方式
    文章目录 一、Mybatis常用模糊查询方法1.使用concat("%",#{name},"%")2.使用'%${name}%'3.使用"%"#{name}"%"总结: ...
    99+
    2023-09-01
    mysql mybatis java
  • 使用Springboot注解形式进行模糊查询
    Springboot注解形式进行模糊查询 需求: 功能需要按照商户名字做模糊查询,sql我们项目中使用的是mybatis封装好的一些常见增删改查方法(通用sql需要在pom.xml文...
    99+
    2022-11-12
  • MyBatis使用Map与模糊查询的方法示例
    当我们的实体类、或者数据库里的表、字段或者参数很多,这个时候考虑使用map 一、使用map传参插入数据 1.编写Dao接口/Mapper层 使用Map做参数 //Dao接口/...
    99+
    2022-11-12
  • Vue实现模糊查询的简单方法实例
    前言 所谓模糊查询就是不需要用户完整的输入或者说全部输入信息即可提供查询服务,也就是用户可以在边输入的同时边看到提示的信息(其实是查询出来匹配到的信息),百度的搜索功能就是很好的模糊...
    99+
    2022-11-12
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作