¿Cómo obtener el número de registros devueltos en un ResultSet?

En Java 6 no hay un método directo que permita obtener el número de registros por una consulta. Hay diferentes formas, pero aquí vamos a describir la más elegantes (a mi humilde entender).

 

Es muy sencillo. Instaciamos el objeto Statement de la siguiente forma:

Session session;

Connection connection;

Statement statement;

/*

[... nos conectamos a la base de datos ...]

*/

//En este caso devolveremos un resultset por el que nos podamos desplazar (ResultSet.TYPE_SCROLL_INSENSITIVE) y no actualizable (ResultSet.CONCUR_READ_ONLY)

Statement statement = session.connection.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE, ResultSet.CONCUR_READ_ONLY);

Resultset resultSet = statement.executeQuery("SELECT * FROM MI TABLA");
//Si la consulta ha devuelto registros if( resultSet.last ){ //Obtenemos el númeo de registro de la última fila int totalRegistros = resultSet.getRow(); //Nos volvemos a posicionar antes de la primera fila para poder tratar el resultset resultSet.beforeFirst(); }

 Con el código anterior resolvemos el problemilla se saber cuantos registros devuelve la consulta que hagamos

 

 

 

Localizar un campo en una base de datos Oracle

Seguro que alguna vez has necesitado localizar un campo en una base de datos Oracle con multitud de tablas y lo único que conocías era el nombre del campo en cuestión. Pues aquí tienes la solución a tu problema. Con la siguiente query puedes localizar cualquier campo en una base de datos Oracle:

 

SELECT OWNER,TABLE_NAME,COLUMN_NAME,DATA_TYPE,NULLABLE FROM ALL_TAB_COLUMNS WHERE (column_name = upper( 'NOMBRE_DEL_CAMPO'));

Localizar un campo en una base de datos Oracle

 

Ejecutar un TestCase desde otro TestSuite en SoapUI

SoapUI soporta como lenguajes de script Groovy y JavaScript, pero en este caso el ejemplo está implementado con Groovy.

A partir de este ejemplo se pueden hacer otras cosas como almacenar valores de propiedades a nivel de proyecto, de testSuite, etc para hacerlas accesibles a un objeto Transfer Properties.

En otra entrega mostraré como ejecutar un ws cambiado el endPoint que almacenaremos en un fichero de propiedades


import com.eviware.soapui.support.GroovyUtils
//Creamos un obj GroovyUtils
def groovyUtils = new GroovyUtils(context) 

//Workspace
def workspace = testRunner.testCase.testSuite.project.workspace

//Proyecto que contiene el TestCase a invocar (TestCase invocado)
def prjExterno = workspace.getProjectByName("prjExterno")

//Obtenemos la referencia al testSuite almacenado en el proyecto anterior
def testSuiteExterno = prjExterno.testSuites['TestSuite_Externo']

//Obtenemos la referencia al testCase que queremos ejecutar
def testCaseExterno = testSuiteExterno.testCases['TestCase_Externo']

//Obtenemos una referencia al paso del test case que queremos ejecutar
def testStepExterno = testCaseExterno.getTestStepByName("stepExterno")

//Ejecutamos el step para generar el token de seguridad (Las variables testRunner y context las provee SoapUI en el entorno)
def runner = testStepExterno.run(testRunner, context)
Tags: ,

Subcategorías

Logo M4 ERP
Developer

Seguridad de la página de inicio

Please publish modules in offcanvas position.