Java与数据库(Mysql)打交道的时候,经常会出现一个错误:No operations allowed after connection closed.字面意思是:连接关闭后,不允许执行任何操作。
问题描述:struts2一个小项目中,要删除用户之前上传的照片。上传照片是通过上传到数据库中picture表(id,uid,name,url,这里uid是用户id,是自动增长)关于照片的相关信息(没有存放照片本身);和在服务器上存放照片本身(copy)。所以在删除数据库时,就要删除这两个方面。
删除数据库中的信息:直接在Action中调用DAO的方法删除数据库中照片的记录
删除服务器上存放的照片文件:其实就是找到照片文件存放的目录,删除这个照片文件。这里需要得到绝对路径(上传照片时是传入的相对路径)。相对路径可以在DAO中写一个根据前端传来的id值得到URL(相对路径)的方法,在Action中调用DAO中的这个方法。
出现问题的代码:
//删除照片
public String deletepic()
{
//删除服务器端上传的照片文件的方法
String path=(());//第一次调用dao中方法
//获取appliction对象,以获取绝对路径
ServletContext application= ();
path=("")+path;
//封装成一个File文件,然后调用FileUtils中的方法去删除该文件
File myFile=new File(path);
(myFile);
//删除数据库中记录的方法
(());//第二次调用DAO中的方法
return null;
}
原因:是因为在这个deletepic的方法中要做两件事情:(两次调用dao中的方法)
(1)删除数据库中关于照片的信息记录 要调用DAO中的deletepic方法,此时方法中的conn已经关闭
(2)删除在服务器中保存着的照片文件 要调用DAO中的getURl方法,此时没有重新获取conn,所以报错。
解决:这就要求我们在编写数据库中方法时要注意代码的规范性。 一般每个方法都要先判断是否关闭了共用的数据库连接conn if(())
{
conn=();
}
然后在方法结尾关闭数据库的连接 ();
示例:DAO中方法根据id值删除数据库中记录方法
//一、删除照片在数据库中记录的方法
public void deletepicture(int id)
{
try {
if(())
{
conn=();
}
} catch (SQLException e) {
// TODO Auto-generated catch block
();
}
sql="delete from pictures where id=?";
try {
ps= (sql);
(1, id);
();
();
} catch (SQLException e) {
// TODO Auto-generated catch block
();
}
}