java - ResultSet 关闭后不允许执行 SQLException 操作

标签 java sql unit-testing junit controller

我正在尝试为通过 html 表单中的文本框检索的查询编写 JUnit 测试。文本检索已经过测试并且可以工作,但我的单元测试失败了。我正在使用 2 个相关的类:QueryController 和 QueryControllerTest。我一直在研究在这两个类中关闭的时间和内容,并不断收到错误:ResultSet 关闭后不允许操作。

QueryControllerTest.java

 import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import org.junit.Test;
import static org.junit.Assert.*;

public class QueryControllerTest {

@Test
public void testQuery() {
    ResultSet testRs = null;
    Connection conn = null;
    try {
        Class.forName("com.mysql.jdbc.Driver");

        String connectionUrl = "jdbc:mysql://localhost:3306/test";
        String connectionUser = "root";
        String connectionPassword = "GCImage";
        conn = DriverManager.getConnection(connectionUrl,
                connectionUser, connectionPassword);
        Query testQuery = new Query();
        testQuery
                .setQuery("select * from service_request where FN_contact = 'Greg'");
        testRs = QueryController.executeSelect(conn, testQuery);

        assertEquals("Laughlin", testRs.getString("LN_contact"));
        assertEquals("Hello World", testRs.getString("Notes"));
    } catch (ClassNotFoundException e) {
        e.printStackTrace();
    } catch (SQLException e) {
        e.printStackTrace();
    } finally {
        try {
            testRs.close();
            conn.close();
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }

}
}

QueryController.java

import java.util.Map;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.ModelAttribute;
import org.springframework.web.bind.annotation.RequestMapping;

@Controller
public class QueryController {
@RequestMapping(value = "/query")
public String processRegistration(@ModelAttribute("query") Query query,
        Map<String, Object> model) {

    String queryString = query.getQuery();

    if (queryString != null && !queryString.isEmpty()) {
        System.out.println("query (from controller): " + queryString);
        Connection conn = null;
        try {
            Class.forName("com.mysql.jdbc.Driver");
            String connectionUrl = "jdbc:mysql://localhost:3306/test";
            String connectionUser = "root";
            String connectionPassword = "GCImage";
            conn = DriverManager.getConnection(connectionUrl,
                    connectionUser, connectionPassword);
            if (queryString.toLowerCase().startsWith("select")) {
                ResultSet rs = executeSelect(conn, query);
            } else {
                int rowsUpdated = executeUpdate(conn, query);
                System.out.println(rowsUpdated + " rows updated");
            }
        } catch (Exception e) {
            e.printStackTrace();
        } 

    }

    return "query";
}

public static ResultSet executeSelect(Connection conn, Query query) {
    ResultSet rs = null;
    Statement stmt = null;
    try {
        stmt = conn.createStatement();
        rs = stmt.executeQuery(query.getQuery());
        while (rs.next()) {
            String id = rs.getString("ID");
            String firstName = rs.getString("FN_Contact");
            String lastName = rs.getString("LN_Contact");
            String notes = rs.getString("Notes");
            System.out.println("ID: " + id + ", First Name: " + firstName
                    + ", Last Name: " + lastName + ", Notes: " + notes);
        }
    } catch (Exception e) {
        e.printStackTrace();
    } finally {
        try {
            if(rs!=null){
                rs.close();
            }
            if(stmt != null){
                stmt.close();
            }
            if (conn != null)
                conn.close();
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }
    return rs;
}
}

最佳答案

QueryController.executeSelect正在调用rs.close(),但是QueryControllerTest.testQuery中的assertEquals正在调用testRS上的方法。由于executeSelect正在返回结果集,因此首先关闭它是没有意义的。此外,executeSelect 正在传递连接,因此它也不应该关闭该连接(如果调用者想要在同一连接上执行两个不同的选择,会发生什么?)。

关于java - ResultSet 关闭后不允许执行 SQLException 操作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32835023/

相关文章:

javascript - Angularjs ngMock 在每次测试之前或在每个测试用例上注入(inject)?

java - JPQL验证错误

java - Oracle 的 Java 和 Android 中使用的 Java 有什么区别吗?

java - 使用 Stax Parser 解析特定属性值的 XML 字符

c# - 将 int 转换为 nvarchar 时出错

sql - 如何选择字段名称包含点的列

mysql - 连接同一服务器上的两个不同数据库,不同的用户名和密码

javascript - 如何伪造 jquery.ajax() 响应?

javascript - 将测试中的日期与 Jasmine 进行比较时出错

JavaFX TableView ScrollBar 值说明