欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

关于目录遍历与like查询解决方案

程序员文章站 2022-04-26 10:03:12
...
关于目录遍历与like查询
有一朋友现在遇到一个问题,有一目录存放的是图片文件,目录结构为三层,/uploads/avator/140320/*.jpg
也就是avator目录下有很多以目期命名的子目录,大概几百了。整个avator目录大概有8W左右的文件,其中有一部分文件
是无用了的垃圾文件,他想清掉。
这个目录中的大部分文件有一个表中的img_url字段记录了完全路径,即 路径+文件名, 比如:/upload/avator/140320/bid001.jpg。

他现在的作法是,遍历目录拿到所有文件名,然后查表 select 查 img_url like '%K',如果返回记录数等于0,就把这个文件从目录中删除掉。

表中的记录数有6W多条。

等于说有2W左右的文件是可删除的。

但是从运行来看,遍历目录很快,但是like时太慢了。。有没有更好更快的办法呀。

img_url字段建了索引
------解决思路----------------------
既然表中存放有完整的路径,那为什么还 like 呢?直接 = 不就快些

读取目录 glob('/uploads/avator/*/*.jpg') 放到一个临时表中
用这个临时表左连接数据表,右表为 null 的就是该删除的文件
------解决思路----------------------
img的src=“”时, 会导致有些浏览器显示一个x。 所以是不推荐将img的src设置为空的,。比较好的方案是remove image这个元素节点。
------解决思路----------------------
%开头的like是不启用索引的,像斑竹说的直接=
要么换个角度,遍历数据库,将有用的图片剪切到一个新文件夹,然后你懂的
关于目录遍历与like查询解决方案

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

相关文章

相关视频