PHP模糊查询的实现方法(推荐)


Posted in PHP onSeptember 06, 2016

模式查询

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%';
#查询包含三个字符的用户
SELECT * FROM user WHERE username LIKE '___';
#查询用户名第二个字符为o的用户:_o%
SELECT * FROM user WHERE username LIKE '_o%';

正则表达式匹配模式

通配符(正则表达式)

.匹配任意的单个字符

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

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

    [..]匹配中括号中的任意字符
    [abc]匹配字符ab或c
    [a-z]匹配任意字母
    [0-9]匹配任意数字
    [0-9]*匹配任意数量的任何数字
    [a-z]*匹配任何数量的字母

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

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

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

REGEXP 或 NOT REGEXP(RLIKE 或 NOT RLIKE)

注意:正则表达式匹配模式,其正则表达式出现在匹配字段的任意位置,

其模式就算匹配了,不必在两侧放一个通配符来使得其匹配;

如果仅用通配符 . 来匹配,假设N个,那么其匹配模式表示,大于等于N个;

怎么理解上面这句话呢?

就是说

...   匹配大于等于3个字符的数据
....  匹配大于等于4个字符的数据
#查询用户名以字符 l开头的用户:^l;
#正则表达式写法

SELECT * FROM user WHERE username REGEXP '^l';
#sql匹配模式写法:
SELECT * FROM user WHERE username LIKE 'l%';
#查询用户名正好是三个字符的用户:^...$;
#sql匹配模式写法:
SELECT * FROM user WHERE username LIKE '___';
#正则表达式写法
SELECT * FROM user WHERE username REGEXP '^...$';

以上这篇PHP模糊查询的实现方法(推荐)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

PHP 相关文章推荐
一个简单的自动发送邮件系统(二)
Oct 09 PHP
PHP 应用程序的安全 -- 不能违反的四条安全规则
Nov 26 PHP
PHP 小心urldecode引发的SQL注入漏洞
Oct 27 PHP
如何用PHP实现插入排序?
Apr 10 PHP
php中sprintf与printf函数用法区别解析
Feb 17 PHP
解决PhpMyAdmin中导入2M以上大文件限制的方法分享
Jun 06 PHP
PHP伪静态Rewrite设置之APACHE篇
Jul 30 PHP
PHP使用自定义方法实现数组合并示例
Jul 07 PHP
ThinkPHP中类的构造函数_construct()与_initialize()的区别详解
Mar 13 PHP
Yii2中简单的场景使用介绍
Jun 02 PHP
PHP注释语法规范与命名规范详解篇
Jan 21 PHP
PHP实现的多维数组排序算法分析
Feb 10 PHP
浅谈PHP中的数据传输CURL
Sep 06 #PHP
PHP实现页面静态化的超简单方法
Sep 06 #PHP
基于PHP实现短信验证码接口(容联运通讯)
Sep 06 #PHP
PHP7 新特性详细介绍
Sep 06 #PHP
PHP会员找回密码功能的简单实现
Sep 05 #PHP
浅谈php中urlencode与rawurlencode的区别
Sep 05 #PHP
浅谈mysql_query()函数的返回值问题
Sep 05 #PHP
You might like
PHP 多维数组的排序问题 根据二维数组中某个项排序
2011/11/09 PHP
Codeigniter中mkdir创建目录遇到权限问题和解决方法
2014/07/25 PHP
兼容多浏览器的字幕特效Marquee的通用js类
2008/07/20 Javascript
Jquery实现自定义弹窗示例
2014/03/12 Javascript
js 验证身份证信息有效性
2014/03/28 Javascript
javascript中$(function() {});写与不写有哪些区别
2015/08/10 Javascript
Boostrap入门准备之border box
2016/05/09 Javascript
jQuery EasyUI 右键菜单--关闭标签/选项卡的简单实例
2016/10/10 Javascript
taro 实现购物车逻辑的实例代码
2020/06/05 Javascript
Python的类实例属性访问规则探讨
2015/01/30 Python
Python科学画图代码分享
2017/11/29 Python
windows下安装Python的XlsxWriter模块方法
2018/05/03 Python
在python中实现将一张图片剪切成四份的方法
2018/12/05 Python
浅谈Python中的全局锁(GIL)问题
2019/01/11 Python
pycharm修改file type方式
2019/11/19 Python
Python接口自动化判断元素原理解析
2020/02/24 Python
python爬虫开发之Request模块从安装到详细使用方法与实例全解
2020/03/09 Python
Python迭代器协议及for循环工作机制详解
2020/07/14 Python
英国街头品牌:Bee Inspired Clothing
2018/02/12 全球购物
Booking.com亚太地区:Booking.com APAC
2020/02/07 全球购物
在Ajax应用中信息是如何在浏览器和服务器之间传递的
2016/05/31 面试题
如何执行一个shell程序
2012/11/23 面试题
求职意向书
2014/04/01 职场文书
高一学生评语大全
2014/04/25 职场文书
销售求职信范文
2014/05/26 职场文书
财政局党的群众路线教育实践活动剖析材料
2014/10/13 职场文书
投标承诺函范文
2015/01/21 职场文书
奖励通知
2015/04/22 职场文书
作息时间调整通知
2015/04/22 职场文书
2015年禁毒工作总结
2015/04/30 职场文书
幸福终点站观后感
2015/06/04 职场文书
篮球赛新闻稿
2015/07/17 职场文书
2016年党员干部廉政承诺书
2016/03/24 职场文书
公司要求试用期员工提交“述职报告”,该怎么写?
2019/07/17 职场文书
AJAX学习笔记
2021/05/18 Javascript
Pandas 稀疏数据结构的实现
2021/07/25 Python