qq_66972778 2023-04-16 17:47 采纳率: 33.3%
浏览 39
已结题

web中项目rs.next报错

判断rs不为空,但是rs.next却会报错,控制台显示的是rs.next和rs = pstmt.executeQuery()这两句报错,找了好久不知道错在哪里

img

img

img

img

  • 写回答

2条回答 默认 最新

  • Huazie 全栈领域优质创作者 2023-04-16 17:57
    关注

    使用结果集之前,你已经 关闭了结果集了,当然有问题了

    img

    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.ResultSet;
    import java.sql.SQLException;
    import java.sql.Statement;
    
    /**
     * @author huazie
     * @version 2.0.0
     * @since 2.0.0
     */
    public class DBUtil {
    
        private DBUtil() {
        }
    
        static {
            try {
                Class.forName("com.mysql.cj.jdbc.Driver");
            } catch (ClassNotFoundException e) {
                // 打印异常
            }
        }
    
        /**
         * 获取数据库连接对象
         *
         * @param url  数据库URL
         * @param name 用户名
         * @param pwd  密码
         * @return 数据库连接对象
         */
        public static Connection getConnection(String url, String name, String pwd) throws SQLException {
            return DriverManager.getConnection(url, name, pwd);
        }
    
        /**
         * <p> 释放连接Connection </p>
         *
         * @param conn 数据库连接对象
         */
        private static void closeConnection(Connection conn) {
            try {
                if (null != conn) {
                    conn.close();
                }
            } catch (SQLException e) {
                // 打印异常
            }
        }
    
        /**
         * <p> 释放statement </p>
         *
         * @param statement Statement对象
         */
        private static void closeStatement(Statement statement) {
            try {
                if (null != statement) {
                    statement.close();
                }
            } catch (SQLException e) {
                // 打印异常
            }
        }
    
        /**
         * <p> 释放ResultSet结果集 </p>
         *
         * @param rs 结果集对象
         */
        private static void closeResultSet(ResultSet rs) {
            try {
                if (null != rs) {
                    rs.close();
                }
            } catch (SQLException e) {
                // 打印异常
            }
        }
    
        /**
         * <p> 释放资源 </p>
         *
         * @param conn      数据库连接对象
         * @param statement 数据库状态对象
         * @param rs        数据库结果集对象
         */
        public static void close(Connection conn, Statement statement, ResultSet rs) {
            closeResultSet(rs);
            closeStatement(statement);
            closeConnection(conn);
        }
    
        /**
         * <p> 释放连接 </p>
         *
         * @param conn 数据库连接对象
         */
        public static void close(Connection conn) {
            closeConnection(conn);
        }
    
        /**
         * <p> 释放状态 </p>
         *
         * @param statement 数据库状态对象
         */
        public static void close(Statement statement) {
            closeStatement(statement);
        }
    
        /**
         * <p> 释放结果集 </p>
         *
         * @param rs 数据库结果集对象
         */
        public static void close(ResultSet rs) {
            closeResultSet(rs);
        }
    }
    
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
    1人已打赏
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 4月24日
  • 已采纳回答 4月16日
  • 创建了问题 4月16日

悬赏问题

  • ¥15 2024-五一综合模拟赛
  • ¥15 下图接收小电路,谁知道原理
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度
  • ¥30 关于#r语言#的问题:如何对R语言中mfgarch包中构建的garch-midas模型进行样本内长期波动率预测和样本外长期波动率预测
  • ¥15 ETLCloud 处理json多层级问题
  • ¥15 matlab中使用gurobi时报错
  • ¥15 这个主板怎么能扩出一两个sata口
  • ¥15 不是,这到底错哪儿了😭