首页 >

PHP如何进行模糊查询

后端开发|PHP问题PHP如何进行模糊查询
php,模糊匹配
后端开发-PHP问题
微信 聊天机器人 源码,vscode如何折叠文字,ubuntu笔记,tomcat 设置端口,sqlite as3,伊利网页设计师,.net 数据库缓存依赖,linux cdn服务器,discuz 头像上传插件,前端所有标签框架名称,爬虫抓包工具,php 创建数据库,词库seo,springboot报表,织梦首页分页标签,jsp购物网站模板,网页字符解密,发红包通知模板,wp后台登陆不进去,简单登录页面html代码下载,火车票信息管理系统,网站同步小程序lzw
在搭建网站的时候,经常会使用到使用关键词查找网站某些资源的这个功能,这时候我们往往需要用到模糊查询。今天学习了一下PHP的模糊查询,现在来总结一下。
源码框架的网站,ubuntu使用qq邮箱,济南哪里卖爬虫,php_apache,seo图片描述lzw
PHP如何进行模糊查询
飘零1.5源码,ubuntu18 acpi,基础爬虫的作用,php post[,岑溪seo推广lzw
以上为模糊查询的流程图。

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

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(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如何进行模糊查询
  • 正则表达式实现字符的模糊匹配功能示例
  • 正则表达式实现字符的模糊匹配功能示例 | 正则表达式实现字符的模糊匹配功能示例 ...

    PHP如何进行模糊查询
  • Laravel5中实现模糊匹配加多条件查询功能办法
  • Laravel5中实现模糊匹配加多条件查询功能办法 | Laravel5中实现模糊匹配加多条件查询功能办法 ...

    PHP如何进行模糊查询
  • 模糊匹配 - LeanCloud php 怎么实现模糊查询?
  • 模糊匹配 - LeanCloud php 怎么实现模糊查询? | 模糊匹配 - LeanCloud php 怎么实现模糊查询? ...