只能删除数据库里的图片路径字段,如何实现一并删除文件夹下的对应图片?

icefreezing 2010-01-07 01:02:36
我的代码是:
protected void GridView1_RowDeleting(object sender, GridViewDeleteEventArgs e)
{
int sid = (int)GridView1.DataKeys[e.RowIndex].Value;
Response.Write(sid);
string sql = "DELETE FROM CompanyPic where id=" + sid;
norke.DoSql(sql);
bind();
}
这样只能删除数据库里图片的存储路径那个字段,虽然用户感觉好像是图片已经删除了,但是不能实现文件夹下对应图片的真正删除。这样长久下去我那100M的SQL数据库服务器空间肯定会超出100M这么大空间的。
我该如何实现? 麻烦能给出参照的详细代码。谢谢
...全文
356 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
fly600 2010-01-07
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 icefreezing 的回复:]
我在上传图片时,是存储的相对路径,存储图片的代码如下所示:
FileUpload1.PostedFile.SaveAs(Server.MapPath(".\\CompanyPic\\" + newname + newext));
然后用insert语句将其路径插入到CompanyPic的pic字段中。

那么我在删除图片时,利用File.Delete(查询出的路径)实现真正删除图片时, “查询出的路径”就直接查询出的pic字段就是了吗?
[/Quote]
没错,但是查询出的路径也要和上面的一样 File.Delete("~\CompanyPic\" + PIC字段)
icefreezing 2010-01-07
  • 打赏
  • 举报
回复
我在上传图片时,是存储的相对路径,存储图片的代码如下所示:
FileUpload1.PostedFile.SaveAs(Server.MapPath(".\\CompanyPic\\" + newname + newext));
然后用insert语句将其路径插入到CompanyPic的pic字段中。

那么我在删除图片时,利用File.Delete(查询出的路径)实现真正删除图片时, “查询出的路径”就直接查询出的pic字段就是了吗?
liu_angelkismet 2010-01-07
  • 打赏
  • 举报
回复
删除前可以先取到该ID的对应图片路径,通过该路径使用流删除掉目录下的图片,然后再删掉数据库。
孟子E章 2010-01-07
  • 打赏
  • 举报
回复

string sql = "Select 路径字段 FROM CompanyPic where id=" + sid;
File.Delete(查询出的路径)
sql = "DELETE FROM CompanyPic where id=" + sid;
norke.DoSql(sql);

62,254

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧