/*
* Sistema de Ouvidoria: um canal através do qual os usuários
* podem encaminhar suas reclamações, elogios e sugestões.
*
* Copyright (C) 2011 SERPRO
*
* Este programa é software livre; você pode redistribuí-lo e/ou
* modificá-lo sob os termos da Licença Pública Geral GNU, conforme
* publicada pela Free Software Foundation; tanto a versão 2 da
* Licença como (a seu critério) qualquer versão mais nova.
*
* Este programa é distribuído na expectativa de ser útil, mas SEM
* QUALQUER GARANTIA; sem mesmo a garantia implícita de
* COMERCIALIZAÇÃO ou de ADEQUAÇÃO A QUALQUER PROPÓSITO EM
* PARTICULAR. Consulte a Licença Pública Geral GNU para obter mais
* detalhes.
*
* Você deve ter recebido uma cópia da Licença Pública Geral GNU,
* sob o título "LICENCA.txt", junto com esse programa. Se não,
* acesse o Portal do Software Público Brasileiro no endereço
* http://www.softwarepublico.gov.br/ ou escreva para a Fundação do
* Software Livre (FSF) Inc., 51 Franklin St, Fifth Floor, Boston,
* MA 02111-1301, USA.
*
* Contatos através do seguinte endereço internet:
* http://www.serpro.gov.br/sistemaouvidoria/
*/
package br.gov.serpro.ouvidoria.util;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.List;
/**
* Objetivo: Classe utilitária para realizar consultas SQL Nativas, sem passar pela API
* do Hibernate (é utilizada a conexão obtida da sessão do Hibernate).
*
* @author SERPRO
* @version $Revision: 1.1.2.3 $, $Date: 2011/10/20 15:30:35 $
* @version 0.1, Date: 2005/01/21
*/
public class NativeSqlHelper {
private NativeSqlHelper() {
}
/**
* Executa uma consulta SQL diretamente no BD, sem passar pelo Hibernate
* (utiliza a conexão obtida da sessão do Hibernate).
*
* O segundo argumento deste método deve conter uma lista dos argumentos
* de query, caso o comando sql inclua argumentos (indicados por um
* caractere "?" dentro da string sql). Caso não haja argumentos de query,
* deve-se passar null (ou uma lista vazia) para esse argumento.
*
* @param sql string contendo o SQL a ser executado.
* @param argumentosDeQuery lista (java.util.List) ordenada dos argumentos
* de query, se houver.
*/
public static ResultSet query( String sql, List argumentosDeQuery )
throws SQLException {
//obter a conexão da sessão do Hibernate
Connection c = HibernateSessionFactory.getFactory().getSession().connection();
//criar o prepared statement
PreparedStatement ps = c.prepareStatement( sql );
//configurar os argumentos de query (se houver)
if ( argumentosDeQuery != null ) {
for ( int i = 0; i < argumentosDeQuery.size(); i++ ) {
Object argumento = argumentosDeQuery.get( i );
if ( argumento instanceof java.lang.String ) {
ps.setString( i + 1, (String) argumento );
} else if ( argumento instanceof java.util.Date ) {
ps.setDate( i + 1, (java.sql.Date) argumento );
} else if ( argumento instanceof java.lang.Integer ) {
ps.setInt( i + 1, ((Integer) argumento).intValue() );
} else if ( argumento instanceof java.lang.Long ) {
ps.setLong( i + 1, ((Long) argumento ).longValue() );
} else {
throw new RuntimeException( "Agumentos do tipo "
+ argumento.getClass().getName()
+ " nao são suportados neste helper." );
}
}
}
//executar a query, guardando resultados num ResultSet
ResultSet rs = ps.executeQuery();
return rs;
}
}