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!!!
En este post dejo una forma de como utilizar imágenes en un JTable ademas de implementar MouseListener para realizar dif[...]
El manejo correcto de excepciones permite que nuestras aplicaciones sean robustas, tolerante a fallos y amigable con el[...]
Python es un lenguaje de programación interpretado, de programación multiparadigma, ya que soporta orientación a objeto[...]
Si necesitamos mostrar gráficos estadísticos en nuestras aplicaciones android, contamos con muchas librerías disponibles[...]
SQLite es un sistema de gestión de bases de datos relacional, escrita en C, si se desea hacer uso de encriptación con S[...]
En este post conocernos lo que son las Estructuras de Control IF en los script de Bash. Estas estructuras nos ayudan a c[...]