Los procedimientos almacenados no solo pueden retornar valores como números, cadenas, etc, sino también datos como los Result Set o Conjunto de Resultados que no son otra cosa que las filas obtenidas por una consulta SQL.
Por ejemplo si partimos de la siguiente tabla «empleado»
Podemos definir un procedimiento para que dado el parámetro de entrada «código de cargo» nos retorne una tabla con los datos de los empleados que cumplen dicho requisito.
El asistente gráfico de phpMyAdmin nos permite crear procedimientos almacenados muy fácilmente, sin embargo también podemos crearlos directamente desde SQL, por ejemplo:
Y para ejecutar el SQL, presionamos el botón [Continuar]
Realizamos una prueba con el parámetro de entrada «codigo» = «CMO» y obtenemos:
Result Set en Java
Ahora para obtener el Result Set desde código java, realizamos lo siguiente:
import java.sql.CallableStatement; import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Types; /** * @see https://www.jc-mouse.net/ * @author mouse */ public class Main { public static void main(String[] args) { Connection connection = conectar("jdbc:mariadb://localhost:3306/TutorialJava", "root", ""); if (connection != null) { try { System.out.println("> Se prepara llamada a procedimiento almacenado"); CallableStatement stmt = connection.prepareCall("{call empleadosPorCargo(?)}"); //ingresando parametro INOUT de tipo VARCHAR stmt.registerOutParameter(1, Types.VARCHAR); stmt.setString(1, "CMO"); System.out.println("> Ejecutando procedimiento"); stmt.execute(); System.out.println("> Ejecucion terminada"); // Obtiene el Result Set ResultSet resultSet = stmt.getResultSet(); //Imprime en pantalla el resultado System.out.printf("%-4s | %-30s | %-30s |\n", "ID", "NOMBRE", "CARGO"); while (resultSet.next()) { int id = resultSet.getInt("id"); String nombre = resultSet.getString("nombre"); String cargo = resultSet.getString("cargo"); System.out.printf("%-4s | %-30s | %-30s |\n", id, nombre, cargo); } } catch (SQLException ex) { System.err.println(ex.getMessage()); } } } public static Connection conectar(String url, String user, String pass) { try { Connection connection = DriverManager.getConnection(url, user, pass); System.out.println("> Conectado a la base de datos"); return connection; } catch (SQLException ex) { System.err.println(ex.getMessage()); } return null; } }
Y como resultado obtenemos:
enjoy!!!
El gráfico de columnas es uno tipo de gráfico que nos permite representar fácilmente la cantidad de veces que ocurre un[...]
En este post haremos uso de PanoramaImageView para agregar a una aplicación android, una vista panorámica de 180° y 360°[...]
En este post, crearemos una aplicación java que nos permita arrastrar un archivo excel hacia la aplicación, abrirlo y ca[...]
La siguiente clase reproduce sonidos WAV en controles Swing de Java Netbeans, los controles son pasados en el constructo[...]
En este post diseñaremos un reporte de un padrón electoral con dos columnas que contendrá los certificados de sufragio e[...]
JSON es un formato de texto ligero para el intercambio de datos ampliamente usado en los Servicios Web. En este post uti[...]