0

我有一个连接到 Oracle 数据库的 java 应用程序。我有一个表单,用户在其中输入一个名为的 ID COMMUNITY_ID、一个名为的开始日期START_DATE和一个名为的结束日期END_DATE

我希望应用程序在数据库中的表中搜索输入的值,当搜索结果正确时,我希望它显示总值的总和。

我有三种方法;每个方法负责搜索单个文本框。例如,第一个方法total 1搜索 ,COMMUNITY_ID第二个方法搜索 ,START_DATE最后一个方法搜索END_DATE

我收到一条错误消息,指出结果集为空或已关闭。我不知道为什么,因为我没有清楚地理解信息。

以下是我的代码。如果有人知道如何解决它,请帮助我。

public void total3()
{
    ResultSet result;
    System.out.println("total 3");

    String endDate = this.EndTxtBox.getText();

    try
    {
        rs=st.executeQuery("select RECIPT_ID,COMMUNITY_ID,VALUE,START_DATE,END_DATE, ITEM_BOUGHT,REASON from RECIPTS where  END_DATE = '" +endDate+"'");
        //display();
        this.EndTxtBox.setText(rs.getString("END_DATE"));
    }
    catch(Exception ex)
    {

        JOptionPane.showMessageDialog(null, "Searched Failed" + ex);
    }

    try
    {
        result =  rs=st.executeQuery("select SUM(VALUE)from RECIPTS where END_DATE = '" +endDate+"'" );
        //result =  rs=st.executeQuery("select RECIPT_ID,COMMUNITY_ID,VALUE,START_DATE,END_DATE, ITEM_BOUGHT,REASON,SUM(VALUE)from RECIPTS group by RECIPT_ID,COMMUNITY_ID,VALUE,START_DATE,END_DATE, ITEM_BOUGHT,REASON ");
    }
    catch(Exception ex)
    {
        JOptionPane.showMessageDialog(null, "Error" + ex);
    }
}

请问有什么想法吗?它有什么问题?

4

1 回答 1

3

您试图在转到第一行之前从结果集中读取:

if (rs.next()) {
    endDate = rs.getString("END_DATE");
}

您的代码充满了不良做法:

  • 将 UI 代码与数据库访问代码混合
  • 捕捉异常
  • 当您只对其中一个感兴趣时选择一大堆行和列
  • 不使用准备好的语句
  • 使用resultrs做同一件事
  • 不关闭语句和结果集
  • 使用字符串变量存储日期
  • 缩进不佳且不一致
于 2012-06-14T17:22:10.053 回答