通配符*匹配功能在MySQL查询中的实现是怎样的,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。
目前成都创新互联已为近千家的企业提供了网站建设、域名、虚拟空间、网站托管运营、企业网站设计、卧龙网站维护等服务,公司将坚持客户导向、应用为本的策略,正道将秉承"和谐、参与、激情"的文化,与客户和合作伙伴齐心协力一起成长,共同发展。
今日在做站内短消息发送的时候,遇到一个功能,就是要做帐号的通配符搜索
以下几种情况,都有可能在搜索的时候用到
sunzhongshan 字符串无通配符搜索
sun* 以sun开头
*shan 以shan结尾
sun*shan 以sun开头,以shan结尾
*zhong* 包含zhong
sun*ong* 以sun开头,包含ong
开始想的是做判断,如果以*开头怎么处理,以*结尾怎么处理。然后以*做数组分隔符一个个去处理
这样做要用到大量的函数去做判断,觉得有点浪费资源。所以我决定重新思考我的思路。。。。。
。。。。。。。。。。。。。。。。。。。。。。。
sun*最后写成的代码就是usename LIKE 'sun%'
*zhong*最后写成的代码就是usename LIKE '%zhong%'
......................................
这样,我就想能不能将*替换成%再进行处理呢
以sun*zhong*为例子,就可以替换成sun%zhong%,这样看起来貌似可以实现了,但是不好分割,不好转换
最后,终于测试出可以用%,%来替换,替换后就是sun%,%zhong%,%
然后的处理就是用trim()函数来处理前后多出来的%符号
然后用explode()分割成数组,上面的一个字符串经过分割后是array(0=>sun%,1=>%zhong%,2=>)
有空格也好处理,在循环处理的时候直接判断跳过就是。
完成的例子代码:
$sql=" SELECT autoid FROM users WHERE 1=1 ";
$str1='sun*zhong*';
$str11=str_replace('*','%,%',$str1);
$str12=trim($str11,'%');
$str13=explode(",",$str12);
foreach($str13 as $strStr){
if(emptyempty($strStr)){
continue;
}
$sql.=" AND username LIKE '".$strStr."' ";
}
echo $sql;
//执行出来的结果:
//SELECT autoid FROM users WHERE 1=1 AND username LIKE 'sun%' AND username LIKE '%zhong%'
看完上述内容,你们掌握通配符*匹配功能在MYSQL查询中的实现是怎样的的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注创新互联行业资讯频道,感谢各位的阅读!