首页 >后端开发 >PHP问题 >php怎样实现模糊查询

php怎样实现模糊查询

coldplay.xixi
coldplay.xixi原创
2020-08-20 09:46:473950浏览

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

php怎样实现模糊查询

【相关学习推荐:php编程(视频)】

php实现模糊查询的方法:

方法1: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%';

方法2:正则表达式匹配模式

通配符(正则表达式)

.匹配任意的单个字符

*匹配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中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn