模糊查询的方法: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
(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如何进行模糊查询的详细内容。更多信息请关注PHP中文网其他相关文章!

本文比较了酸和基本数据库模型,详细介绍了它们的特征和适当的用例。酸优先确定数据完整性和一致性,适合财务和电子商务应用程序,而基础则侧重于可用性和

本文讨论了确保PHP文件上传的确保,以防止诸如代码注入之类的漏洞。它专注于文件类型验证,安全存储和错误处理以增强应用程序安全性。

本文讨论了在PHP中实施API速率限制的策略,包括诸如令牌桶和漏水桶等算法,以及使用Symfony/Rate-limimiter之类的库。它还涵盖监视,动态调整速率限制和手

本文讨论了使用password_hash和pyspasswify在PHP中使用密码的好处。主要论点是,这些功能通过自动盐,强大的哈希算法和SECH来增强密码保护

本文讨论了OWASP在PHP和缓解策略中的十大漏洞。关键问题包括注射,验证损坏和XSS,并提供用于监视和保护PHP应用程序的推荐工具。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

MinGW - 适用于 Windows 的极简 GNU
这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

SublimeText3 Linux新版
SublimeText3 Linux最新版

DVWA
Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中

Atom编辑器mac版下载
最流行的的开源编辑器

安全考试浏览器
Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。