最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

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

来源:动视网 责编:小采 时间:2020-11-09 18:10:54
文档

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

通配符*匹配功能在MYSQL查询中的个人的一点点思路与实现_MySQL:bitsCN.com 今日在做站内短消息发送的时候,遇到一个功能,就是要做帐号的通配符搜索 以下几种情况,都有可能在搜索的时候用到 sunzhongshan 字符串无通配符搜索 sun* 以sun开头 *shan 以shan结尾 sun*shan 以sun开头,以shan结尾 *zhon
推荐度:
导读通配符*匹配功能在MYSQL查询中的个人的一点点思路与实现_MySQL:bitsCN.com 今日在做站内短消息发送的时候,遇到一个功能,就是要做帐号的通配符搜索 以下几种情况,都有可能在搜索的时候用到 sunzhongshan 字符串无通配符搜索 sun* 以sun开头 *shan 以shan结尾 sun*shan 以sun开头,以shan结尾 *zhon


bitsCN.com

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

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

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

?>

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

bitsCN.com

文档

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

通配符*匹配功能在MYSQL查询中的个人的一点点思路与实现_MySQL:bitsCN.com 今日在做站内短消息发送的时候,遇到一个功能,就是要做帐号的通配符搜索 以下几种情况,都有可能在搜索的时候用到 sunzhongshan 字符串无通配符搜索 sun* 以sun开头 *shan 以shan结尾 sun*shan 以sun开头,以shan结尾 *zhon
推荐度:
标签: 搜索 mysql 字符串
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top