当前位置: 首页 > 知识库问答 >
问题:

jdbc resultset.get返回null

滑畅
2023-03-14

所以我有以下问题。我有一个通过JDBC连接到Redshift-DB的Java应用程序。执行一个简单的SELECT-query会生成一个不为null的ResultSet(我检查过了)。

    private void test(){

    ResultSet rs = null;
    ResultSetMetaData rsmd = null;
    String getTable = "SELECT * from myTable"; //
    try(PreparedStatement prep = myConnection.prepareStatement(getTable
            , ResultSet.TYPE_FORWARD_ONLY
            )){
        rs = prep.executeQuery();
        rsmd = rs.getMetaData();
        int columns = rsmd.getColumnCount();

        while(rs.next()){                               // loop over all rows
            for(int col = 1; col <= columns; col++){
                if(rs.wasNull())
                    System.out.println("NULL Value detected!");

                System.out.println("Column Name: " + rsmd.getColumnName(col));
                System.out.println("Column value: " + rs.getString(col));
            }
        }

    } catch (SQLException e) {
        e.printStackTrace();
    }
}

我尝试使用不同的驱动程序版本,我尝试使用rs.getbytes(col),但结果仍然是一样的:我只是无法删除那些空值。

我还成功地完成了卸载操作,将麻烦的表卸载到S3并手动检查导出的csv文件。卸载运行没有任何问题,CSVs对我来说看起来很好(所有值都像预期的那样)。

现在,我当然可以通过跳过发生这些“不需要的空”的记录来手动处理这些“不需要的空”,但我宁愿避免在不了解其原因的情况下掩盖这种错误。

所以我的问题是:

我在代码中做了什么根本错误的事情吗?jdbc/Redshift是否存在可能导致这种情况的已知问题?有人能给我指出一些来源或者给我一些我可以尝试的想法吗?

共有1个答案

葛季萌
2023-03-14

resultset.wasnull()的javadoc中:

报告上一次读取的列的值是否为SQLnull。请注意,必须首先调用列上的一个getter方法以尝试读取其值,然后调用方法WASNULL以查看读取的值是否为SQLNULL

返回:
 · · true,如果上次读取的列值是SQLnull,则返回false

换句话说,将代码更改为:

while(rs.next()){                               // loop over all rows
    for(int col = 1; col <= columns; col++){
        String value = rs.getString(col);
        if(value == null)
            System.out.println("NULL Value detected!");

        System.out.println("Column Name: " + rsmd.getColumnName(col));
        System.out.println("Column value: " + value);
    }
}

或者,如果您真的想使用wasnull()(但实际上,您不应该!):

while(rs.next()){                               // loop over all rows
    for(int col = 1; col <= columns; col++){
        String value = rs.getString(col);
        if(rs.wasNull())
            System.out.println("NULL Value detected!");

        System.out.println("Column Name: " + rsmd.getColumnName(col));
        System.out.println("Column value: " + value);
    }
}
 类似资料:
  • 问题内容: 例如我有一个功能: 我怎样才能返回AJAX后得到的? 问题答案: 因为请求是异步的,所以您无法返回ajax请求的结果(而同步ajax请求是一个 糟糕的 主意)。 最好的选择是将自己的回调传递给f1 然后,您将像这样致电:

  • 我有两个活动和两个布局。当我在第一个活动中显示列表时,一切都正常,并在单击时给出列表中项目的编号,但当我尝试在第二个活动中重复相同的内容时,它会告诉我RecycleServiceClickListener侦听器为空。 适配器: 第一项活动: 第二项活动: 错误: 我不明白为什么在第一种情况下,它正常处理单击,而在第二种情况下,它说RecyclerViewClickListener为null

  • 问题内容: 我在使用Ajax时遇到问题。 问题是,在获得ajax响应之前,它会返回cnt。因此它总是返回NULL。 有没有办法使正确的返回响应值? 谢谢! 问题答案: 由于AJAX请求是异步的,因此您的cnt变量将在请求返回并调用成功处理程序之前返回。 我建议重构您的代码以解决此问题。 一种方法是从AJAX请求的成功处理程序中调用调用了GetGrantAmazonItemCnt()的任何函数,此方

  • 我想在下面返回JSON。 {“名字”:“杰基”} 新来的春靴在这里。1天大。有没有合适的方法可以做到这一点?

  • 加载样式表,并在用户单击按钮时将其应用于场景 调用getScene()返回null。 函数所在的类是场景的控制器和根节点,我使用SceneBuilder 2.0,并将类设置为加载fxml的控制器,它是一个。 问题代码是类中的一个成员函数,标记是这样的,我可以通过设置按钮来调用它。 完整的代码可以在https://github.com/SebastianTroy/FactorioManufactur

  • 问题内容: 我创建了一个自定义错误类型来包装错误,以便更轻松地在Golang中进行调试。当有打印错误时它可以工作,但是现在引起了恐慌。 演示版 当我调用一个函数时,它不会返回错误,我仍然应该能够包装该错误。 预期的行为是,如果错误为nil,则应该简单地忽略它,不幸的是,它会做相反的事情。 我希望它能打印出来。而是即使错误为nil也会打印。 问题答案: 正在将err变量与nil进行比较,但实际上它是

  • 问题内容: 我正在使用Servlets&Struts2的混合情况下工作。 我正在调用HTTPServlet,并且正在处理数据。 然后,我需要调用struts API在DB中插入数据。 在那我也使用HTTPSession。 所以我打电话 要获取HttpRequest,然后在该struts动作类中进行会话。 Servlet正在调用Struts Action类。 但 始终返回NULL。 是因为它没有被网

  • 问题内容: 我使用osgi + cdi,并且有以下代码: 而且我有以下tasklist.fxml 但是parent.lookup(“#testComboBox”)返回null。怎么解释呢?我已经多次检查ID的名称。 问题答案: 您可以将所需的逻辑放入控制器类中,而不必使用仅在渲染场景之后才能使用的查找。您可以通过注释将元素从FXML文件注入到控制器类中。 查询通常不可靠,我建议避免使用它们。如果您