ResultSet仅在数据库中存在更多行时返回一行

时间:2018-02-27 17:59:05

标签: java resultset

我在这个类中创建了一个名为Executar_Query_Bd_Multiplos_Resultados的java类,作为整数类型的Conectar方法2值(int Integer1,int Integer2)的参数。

查询收到这些值:

"SELECT DS_ESTRATEGY, STRID_ID" +
    "FROM TB_BKOFFICE_ESTRATEGY" +
    "WHERE IN_STRATEGY_ID IN (" + Istrategy1 + "," + Istrategy2 + ")";

上述查询的结果存储在变量ls_command

Executar_Query_Bd_Multiplos_Resultados_Test类中,我进行方法调用(Connect)和第2步参数(179,319),并命令在屏幕上打印String codEstrategies类型的变量。

但Eclipse只在控制台上显示1个结果。查询应该带来2个结果,而不是1.这是Java类的代码和Oracle SQL Developer中执行的查询结果。

public class Executar_Query_Bd_Multiplos_Resultados_Test {

@Before
public void setUp() throws Exception {

    Executar_Query_Bd_Multiplos_Resultados qr_2 = new Executar_Query_Bd_Multiplos_Resultados();
    String codEstrategias = qr_2.Conectar(179, 319);
    System.out.println("Estratégias: " + codEstrategias);

}

@After
public void tearDown() throws Exception {
}

@Test
public void test() {
}
}

public class Executar_Query_Bd_Multiplos_Resultados {
//Variáveis de BD
Connection conOracle = null;
Statement stmtOracle = null;
ResultSet rsetOracle = null;

public String Conectar(int Id_Estrategia1, int Id_Estrategia2) {

    String retorno = "#;-1;@";

    Boolean lb_continuar = true;
    //StringBuilder ls_comando = new StringBuilder();
    String ls_comando = new String();

    try {
        System.out.println("Conectando ao banco de dados Oracle...");
        String url = "";
        try {
            //conectando aos bancos de dados
            Class.forName("oracle.jdbc.driver.OracleDriver");
            url = "jdbc:oracle:thin:@10.5.12.116:1521:desenv01";
            DriverManager.setLoginTimeout(10);
            conOracle = (Connection) DriverManager.getConnection(url, "bkofficeadm", "bkofficeadmdesenv01");
        } catch (SQLException e) {
            System.out.println("falha SQL >> " + e.getMessage());
        } catch (Exception e) {
            //System.out.println("falha geral >> " + e.getMessage());
            e.printStackTrace();
            lb_continuar = false;
        }
        //String teste = "'BKO - Rep Conectividade'";
        if (lb_continuar) {
            System.err.println("Preparando comando...");
            System.out.println("");

            ls_comando = "SELECT  DS_ESTRATEGIA, ID_ESTRATEGIA"+
                                  " FROM TB_BKOFFICE_ESTRATEGIA"+
                                  " WHERE ID_ESTRATEGIA  IN (" + Id_Estrategia1 + ", " + Id_Estrategia2 + ")";  


            System.out.println(ls_comando);

            stmtOracle = conOracle.createStatement();
            stmtOracle.setQueryTimeout(10);
            rsetOracle = stmtOracle.executeQuery(ls_comando.replaceAll("\n", " ").trim());

            if(rsetOracle.next()) {
                retorno   = rsetOracle.getString(1);
            }              
            rsetOracle.close();
            stmtOracle.close();             
            /*
            Para comandos de Insert, Delete, ou Update
            --------------------------------------------------------
            stmtOracle = conOracle.createStatement();
            stmtOracle.setQueryTimeout(10);
            stmtOracle.execute(variavel_comando.toString());
            conOracle.commit();
            stmtOracle.close();
            */
        } 
    } catch (Exception ex) {
        System.out.println("Erro - " + ex.getMessage());
    } finally {
        try {
            if (rsetOracle != null) {
                rsetOracle.close();
            }
        } catch (Exception e) {
            System.out.println("Erro ao fechar rset - " + e.getMessage());
        }
        try {
            if (stmtOracle != null) {
                stmtOracle.close();
            }
        } catch (Exception e) {
            System.out.println("Erro ao fechar stmt - " + e.getMessage());
        }
        try {
            if (conOracle != null && !conOracle.isClosed()) {
                conOracle.close();
            }
            if (conOracle != null && !conOracle.isClosed()) {
                conOracle.close();
            }
        } catch (Exception e) {
            System.out.println("Erro ao fechar con  - " + e.getMessage());
        }
    }
    return retorno;

}
}

SQL Devleoper查询的输出:

Query DB Oracle

Eclipse控制台的输出:

Console Eclipse Result

1 个答案:

答案 0 :(得分:1)

你正在做这个

if(rsetOracle.next()) {
    retorno   = rsetOracle.getString(1);
}   

这只运行一次

请考虑while

List<String> retornos = new ArrayList<>();
while(rsetOracle.next()) {
    retornos.add(rsetOracle.getString(1));
}   

这将一直运行直到你没有行。

如果将来发生这样的事情,您需要将查询修改为select count(*) ...并验证您在数据库工作台和javacode中获得相同的结果。然后你至少知道你有正确的查询,这是你的演示文稿失败。

<小时/>

注意:

我理解这个问题确实与其他问题重复。但是,那些很难搜索。我建议这是一个规范的答案。