批量删除本地文件

本文介绍了一种批量处理文件及数据库记录的方法,包括批量查询与删除数据库记录,并结合实际业务需求,实现批量删除本地文件的功能。

批量删除本地文件

1、批量查询

<!-- 按Id批量查找 -->
	<select id="batchQueryById" parameterType="Long[]" resultMap="BaseResultMap">
		SELECT <include refid="BaseColumnList" />
		FROM t_attachment WHERE f_attachment_id in (
		<foreach collection="array" item="item" separator=",">
			#{item,jdbcType=DECIMAL}
		</foreach>
		)
	</select>

  • select * from TABLE where id in (01,02,03,04) 

2、批量删除xml

<!-- 按Id批量删除 -->
	<delete id="batchDeleteById" parameterType="Long[]">
		DELETE FROM t_attachment WHERE f_attachment_id in (
		<foreach collection="array" item="item" separator=",">
			#{item,jdbcType=DECIMAL}
		</foreach>
		)
	</delete>
3、批量删除本地文件

/**
	 * 批量删除本地文件
	 * 
	 * @param id
	 * @return
	 */
	public BaseRespVO deleteAttachment(@Param("attachmentId") String attachmentId) {
		List<AttachmentEntity> entity = attachmentBO.batchQueryById(attachmentId.split(","));
		int deleteCount = attachmentBO.batchDeleteById(attachmentId.split(","));
		if (deleteCount > 0 && entity != null) {
			for(int i=0;i<entity.size();i++){
			ResourceBundle resource = ResourceBundle.getBundle("conf");
			File file = new File(resource.getString("upload.path") + entity.get(i).getPath());
			if(file.exists()){
				file.delete();
			}}
			return new BaseRespVO();
		} else {
			return new BaseRespVO(2, "没有要删除的记录!");
		}
	}

  1. 从前端传来的值为字符串(id逗号相连),后端接收后split(",")拆分成存入数组;
  2. 批量查询后,for循环来获取路径,resource.getString("upload.path") + entity.get(i).getPath()
  3. 如果存在则删除该文件。




评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值