问题:No operations allowed after connection closed.

关于com.mysql.jdbc.exceptions.jdbc4.MySQLNonTransientConnectionException: No operations allowed after connection closed.

意思很明显:连接已经关闭,无法再访问数据库


具体原因我还说不清楚(有人说是因为静态方法获取连接引起的),DBUtil的代码是这样的:

public class DBUtil {

	
		private static final String driver = "com.mysql.jdbc.Driver";// 数据库驱动
		private static final String url = "jdbc:mysql://localhost:3306/myproject01?useUnicode=true&characterEncoding=UTF-8";// 连接数据库的URL地址,同时设置字符集编码
		private static final String username = "root";// 数据库的用户名
		private static final String password = "root";// 数据库的密码
		// 创建数据库连接对象
		private static Connection conn = null;
		// 静态代码块负责加载驱动
		static {
			try {
				Class.forName(driver);// 加载驱动
			} catch (Exception ex) {
				ex.printStackTrace();
			}
		}
		// 单例模式返回数据库连接对象
		public static Connection getConnection() throws Exception {
			if (conn == null) {
				conn = DriverManager.getConnection(url, username, password);
				return conn;
			}
			return conn;
		}
}

我的解决办法是这样的:

		try {
			conn = DBUtil.getConnection();
			psmt = conn.prepareStatement(sql);
			psmt.setString(1, eName);
			psmt.setString(2, ePassword);
			rs = psmt.executeQuery();

			while (rs.next()) {
				employee.seteId(rs.getInt("e_id"));
				employee.seteName(rs.getString("e_name"));
				employee.seteSex(rs.getString("e_sex"));
				employee.seteBirthday(rs.getDate("e_birthday"));
				employee.setePhone(rs.getString("e_phone"));
				employee.setePlace(rs.getString("e_place"));
				employee.setePassword(rs.getString("e_password"));
				employee.seteJoinTime(rs.getDate("e_jointime"));
				employee.seteIsLead(rs.getBoolean("e_islead"));
			}
		} catch (Exception e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} finally {
			try {
//				if (conn != null) {
//					conn.close();
//				}
				if (psmt != null) {
					psmt.close();
				}
				if (rs != null) {
					rs.close();
				}
			} catch (SQLException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			}
		}

不要关闭数据库连接,及把

//				if (conn != null) {
//					conn.close();
//				}
去掉就可以了

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
引用\[1\]和\[2\]中提到的异常"jdbc4.MySQLNonTransientConnectionException: No operations allowed after connection closed."是由于连接关闭后仍然执行了数据库操作引起的。引用\[3\]中解释了这个异常的原因,即MySQL默认空闲8小时没有操作会自动断开连接。在C3P0连接池中,如果连接空闲超过8小时,MySQL会断开连接,但C3P0并不知道该连接已经失效。当有客户端请求连接时,C3P0会提供这个失效的连接,从而导致上述异常的出现。 解决这个问题的方法是在Spring Boot的application.properties文件中增加DBCP配置。DBCP是Apache Commons DBCP连接池的一种实现,可以用来管理数据库连接。通过配置DBCP的相关参数,可以避免连接空闲超过8小时被MySQL断开的问题,从而解决上述异常。 请注意,具体的DBCP配置参数可能因使用的数据库和连接池的版本而有所不同。你可以根据自己的需求和环境进行相应的配置。 #### 引用[.reference_title] - *1* *3* [解决MySQLNonTransientConnectionException的问题](https://blog.csdn.net/wwwzhouzy/article/details/118710071)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [关于java.sql.SQLNonTransientConnectionException: No operations allowed after connection closed.的解决方案](https://blog.csdn.net/weixin_62338217/article/details/127405066)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值