首页 / PHP / PHP实现模糊查询的方法
PHP实现模糊查询的方法
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了PHP实现模糊查询的方法,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2211字,纯文字阅读大概需要4分钟。
内容图文
![PHP实现模糊查询的方法](/upload/InfoBanner/zyjiaocheng/136/d1bfc4aa97ea414880f304e01050897d.jpg)
模式查询
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 数组处理函数extract详解及实例
php in_array() 检查数组中是否存在某个值详解
PHP magento后台无法登录问题的解决方法
以上就是PHP实现模糊查询的方法的详细内容,更多请关注Gxl网其它相关文章!
内容总结
以上是互联网集市为您收集整理的PHP实现模糊查询的方法全部内容,希望文章能够帮你解决PHP实现模糊查询的方法所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。