No operations allowed after connection closed. 解决办法

Java与数据库(Mysql)打交道的时候,经常会出现一个错误:No operations allowed after connection closed.字面意思是:连接关闭后,不允许执行任何操作。

问题描述:struts2一个小项目中,要删除用户之前上传的照片。上传照片是通过上传到数据库中picture表(id,uid,name,url,这里uid是用户id,picture.id是自动增长)关于照片的相关信息(没有存放照片本身);和在服务器上存放照片本身(copy)。所以在删除数据库时,就要删除这两个方面。

删除数据库中的信息:直接在Action中调用DAO的方法删除数据库中照片的记录

删除服务器上存放的照片文件:其实就是找到照片文件存放的目录,删除这个照片文件。这里需要得到绝对路径(上传照片时是传入的相对路径)。相对路径可以在DAO中写一个根据前端传来的id值得到URL(相对路径)的方法,在Action中调用DAO中的这个方法。


出现问题的代码:

//删除照片
public String deletepic()
{
//删除服务器端上传的照片文件的方法
String path=dao.getUrlById(picture.getId());//第一次调用dao中方法
//获取appliction对象,以获取绝对路径
ServletContext application= ServletActionContext.getServletContext();
path=application.getRealPath("")+path;
//封装成一个File文件,然后调用FileUtils中的方法去删除该文件
File myFile=new File(path);
FileUtils.deleteQuietly(myFile);

//删除数据库中记录的方法
dao.deletepicture(picture.getId());//第二次调用DAO中的方法
return null;
}


原因:是因为在这个deletepic的方法中要做两件事情:(两次调用dao中的方法)
(1)删除数据库中关于照片的信息记录  要调用DAO中的deletepic方法,此时方法中的conn已经关闭
(2)删除在服务器中保存着的照片文件  要调用DAO中的getURl方法,此时没有重新获取conn,所以报错。


解决:这就要求我们在编写数据库中方法时要注意代码的规范性。 一般每个方法都要先判断是否关闭了共用的数据库连接conn     if(conn.isClosed())
{
conn=DBlib.getconn();
}

然后在方法结尾关闭数据库的连接 conn.close();


示例:DAO中方法根据id值删除数据库中记录方法

//一、删除照片在数据库中记录的方法
public void deletepicture(int id)
{
try {
if(conn.isClosed())
{
conn=DBLib.getConn();
}
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
sql="delete from pictures where id=?";
try {
ps= conn.prepareStatement(sql);
ps.setInt(1, id);
ps.executeUpdate();
conn.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}

你可能感兴趣的:(No operations allowed after connection closed. 解决办法)