Aprende Java Aprende Php Aprende C++ Aprende HTML 5 Aprende JavaScript Aprende JSON Aprende MySQL Aprende SQLServer Aprende Visual Basic 6 Aprende PostgreSQL Aprende SQLite Aprende Redis Aprende Kotlin Aprende XML Aprende Linux VSC Aprende Wordpress Aprende Laravel Aprende VueJS Aprende JQuery Aprende Bootstrap Aprende Netbeans Aprende Android
Sigueme en Facebook Sigueme en Twitter Sigueme en Instagram Sigueme en Youtube Sigueme en TikTok Sigueme en Whatsapp
Home / Java / Procedimientos Almacenados: Parámetros OUT

Procedimientos Almacenados: Parámetros OUT

Por jc mouse lunes, mayo 13, 2019

En un post anterior conocimos que es y como funciona un parámetro de entrada IN en procedimientos almacenados y lenguaje java. En este post continuamos con los parámetros de salida OUT.

Utilizaremos la misma base de datos y servidor XAMPP del post anterior (Parametros IN), así también para no repetir lo mismo, se recomienda leer también el apartado de creación, edición y ejecución de procedimientos almacenados desde phpmyadmin.

Parámetros OUT

Una parámetro de salida OUT se usa para pasar información del procedimiento al programa de llamada. Es una variable de solo escritura y no tiene valor hasta que el bloque le asigna un valor.  Una variable pasada en el modo OUT no se le puede asignar un valor predeterminado, tampoco puede ser leído dentro del procedimiento.

El ejemplo para este post sera trivial, consistirá en obtener la cantidad de empleados retornando el total en un parámetro OUT.

Nuestro procedimiento es el siguiente:

OUT parameter

donde:

  1. Nombre de la rutina: cantidadEmpleados
  2. Tipo: PROCEDURE
  3. Dirección: OUT (salida)
  4. Nombre del parámetro: total
  5. Tipo: INT
  6. Código SQL: Se utiliza la palabra reservada INTO para asignar el valor obtenido al parámetro OUT

Ejecuta el procedimiento desde phpMyAdmin

totallity

Código Java

El código para llamar al procedimiento almacenado con parámetro OUT desde java es:

import java.sql.CallableStatement;
import java.sql.Connection;
import java.sql.DriverManager;
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 cantidadEmpleados(?)}");
                //ingresando parametro OUT de tipo INT
                stmt.registerOutParameter(1, Types.INTEGER);
                                                
                System.out.println("> Ejecutando procedimiento");
                stmt.execute();
                System.out.println("> Ejecucion terminada");

                //Se obtiene el valor devuelto por el procedimiento
                int valor = stmt.getInt(1);
                System.out.println("\n   Cantidad de empleados: " + valor);
                
            } 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;
    }
      
}

Ejecutando obtenemos:

son by four

enjoy!

Tags

Artículos similares

Procedimientos Almacenados: Parámetros IN

Una procedimiento almacenado es un conjunto de sentencias de SQL que se pueden almacenar en el servidor, de esta forma n[...]

Leer datos de un REST API con VUE

En este post realizaremos un proyecto en VUE que se conectara a un REST API  y utilizara un servicio del mismo para[...]

FossFLOW – Herramienta de diagramación isométrica de código abierto

FossFLOW es una potente aplicación web progresiva (PWA) de código abierto para crear atractivos diagramas isométricos, s[...]

Personaliza un JComboBox estilo Metro de Windows

Si bien se pueden encontrar en google estilos java (Look and Feel) listos para cambiar la apariencia de nuestras aplicac[...]

Crear componente Switch de Android para Java Swing

En este post crearemos un componente que solo hay en android y que no esta disponible en la paleta de controles de Netbe[...]

Interfaces Funcionales

Una Interface Funcional es una interface que contiene uno y solo un método abstracto aunque puede contener métodos por d[...]