1. java
  2. android
  3. c#
  4. .net
  5. javascript
  6. php
  7. jquery
  8. html
  9. sql

Erro ao retornar dados com retorno CLOB

Boa tarde! Galera estou com um erro ao fazer uma chamada em uma procedure no banco dados, a procedure retorna um tipo CLOB e eu preciso jogar este retorno em uma lista para trabalhar com os dados, porém ao executar o método é gerada a seguinte exception :

oracle.sql.CLOB cannot be cast to java.sql.ResultSet

E nao consegui alguma maneira para converter esta saida CLOB.

abaixo o código que eu estou utilizando

java.sql.Connection conn = null;
        PreparedStatement stmt = null;
        ResultSet rsPosi = null;
        Context initContext = new InitialContext();
        Context envCtx = (Context) initContext.lookup("java:comp/env");
        DataSource ds = (DataSource) envCtx.lookup("jdbc/BASEDESENV");

        conn = ds.getConnection();

        Cliente cli = new Cliente();

        List<Cliente> lista = new ArrayList<Cliente>();
        try {
            CallableStatement cs = conn.prepareCall("{call MINHA_PROCEDURE(?, ?,?,?,?,?,?,?)}");

            cs.setNull(1, java.sql.Types.VARCHAR);
            cs.setNull(2, java.sql.Types.VARCHAR);
            cs.setNull(3, java.sql.Types.VARCHAR);
            cs.setString(4, matricula);
            cs.setNull(5, java.sql.Types.VARCHAR);
            cs.setNull(6, java.sql.Types.VARCHAR);
            cs.setNull(7, java.sql.Types.VARCHAR);
            cs.registerOutParameter(8, OracleTypes.CLOB);

            cs.execute();


            rsPosi =  (ResultSet) cs.getObject(8);

            while (rsPosi.next()) {

                fin.setEMISSAO(rsPosi.getDate("EMISSAO"));

                lista.add(fin);

            }

            cs.close();
            stmt.close();
            rsPosi.close();

        } catch (Exception e) {
            System.out.println("Erro ao gerar dados! " + e.getMessage());
        } finally {
            conn.close();
        }
        return lista;
    }

Dese já muito obrigado.

  • alguma dica sobre o caso ?

    shodaime   10 de ago de 2016
  1. Você vai ver essas setas em qualquer página de pergunta. Com elas, você pode dizer se uma pergunta ou uma resposta foram relevantes ou não.
  2. Edite sua pergunta ou resposta caso queira alterar ou adicionar detalhes.
  3. Caso haja alguma dúvida sobre a pergunta, adicione um comentário. O espaço de respostas deve ser utilizado apenas para responder a pergunta.
  4. Se o autor da pergunta marcar uma resposta como solucionada, esta marca aparecerá.
  5. Clique aqui para mais detalhes sobre o funcionamento do GUJ!

0 resposta

Não é a resposta que estava procurando? Procure outras perguntas com as tags java java-ee jsp jdbc oracle sql ou faça a sua própria pergunta.