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

5年以前  |  阅读数:1199 次  |  编程语言:PHP 

模式查询

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分页显示制作详细讲解
SSH 登录失败:Host key verification failed
获取IMSI
将二进制数据转为16进制以便显示
获取IMEI
贪吃蛇
文件下载
双位运算符
发送邮件
PHP自定义函数获取搜索引擎来源关键字的方法
Java生成UUID
提取后缀名
年的日历图
在Zeus Web Server中安装PHP语言支持
让你成为最历害的git提交人
Yii2汉字转拼音类的实例代码
再谈PHP中单双引号的区别详解
指定应用ID以获取对应的应用名称
Python 2与Python 3版本和编码的对比
php封装的page分页类完整实例