通配符*匹配功能在MYSQL查询中的 个人的一点点思路与实现

来源:网络 责任编辑:栏目编辑 发表时间:2013-07-01 07:23 点击:

 

今日在做站内短消息发送的时候,遇到一个功能,就是要做帐号的通配符搜索

以下几种情况,都有可能在搜索的时候用到

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=>)

有空格也好处理,在循环处理的时候直接判断跳过就是。

 

完成的例子代码:

 

<?php 

$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%'  

?>   

摘自:金色猪子的PHP成长之路

    相关新闻>>

      发表评论
      请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
      用户名: 验证码:点击我更换图片
      最新评论 更多>>

      推荐热点

      • mysql-mmm
      • mysqldump命令——MySQL数据库备份还原
      • Oracle数据导入MySQL的快捷工具:MySQL Migration Toolkit
      • 简简单单储存过程——循环一个select结果集
      • MySQL数据库十大优化技巧
      • Mysql主主复制架构配置
      • Mysql安装笔记
      • MySQL Stmt预处理提高效率问题的小研究
      • Mysql的Procedure 参数为NULL问题分析
      网站首页 - 友情链接 - 网站地图 - TAG标签 - RSS订阅 - 内容搜索
      Copyright © 2008-2015 计算机技术学习交流网. 版权所有

      豫ICP备11007008号-1