Sigueme en Facebook Sigueme en Twitter Sigueme en Instagram Sigueme en Youtube
JC Mouse Bolivia
Index / Base de Datos / Base de Datos / Java / Java / MySQL / Proyectos / Procedimientos almacenados en java

Procedimientos almacenados en java

Autor jc mouse lunes, marzo 5, 2012

En este tuto realizaremos la implementación y ejecución de procedimientos almacenados de MySQL en Java, si quieres darle un repaso a lo que son los «procedimientos en MySQL» te invito a que visites ese post.

¿Que necesitamos?

  • Java
  • Un DBMS (Gestor de Base de Datos) con MySQL
  • Conocimientos  básicos de SQL
  • IDE Netbeans 6.9 o Superior
  • Conector MySQL JDBC  (mysql-connector-java-5.1.6-bin.jar o superior)
Comencemos.
1. Lo primero que necesitamos es una base de datos, debes crear uno en MySQL y agregarle una tabla, la siguiente:
CREATE TABLE jugador (
  id int(2) NOT NULL auto_increment,
  nombre varchar(60) NOT NULL,
  anio_nac int(4) default NULL,
  categoria varchar(20) default NULL,
  PRIMARY KEY  (id)
) ENGINE=MyISAM  DEFAULT CHARSET=utf8 AUTO_INCREMENT=15 ;
2. Ahora crearemos un procedimiento almacenado, la acción de este sera: registrar a un jugador dado su nombre y año de nacimiento, se calculara su edad y dependiendo de esta, se registrara en la categoría correspondiente, de 18 a 20 años en la categoría «Sub 20» , de 21 a 23 años en la categoría «Sub 22», si el rango de edad no entra en ninguno de los anteriores, se registrara al jugador como «Sin categoría».
DELIMITER $
CREATE PROCEDURE registrar_jugador(IN nombre varchar(60) ,
                                   IN anio_nac INT,
                                   OUT resultado TEXT)
BEGIN
DECLARE edad int ;
DECLARE categoria char(20) ;
-- obtiene la edad del jugador
SET edad = ( DATE_FORMAT(now() ,'%Y') - anio_nac );
-- dependiendo de la edad se registra al jugador en diferentes categorias
     CASE
        WHEN edad=18 OR edad=19 OR edad=20 THEN SET categoria = 'Sub 20'  ;
        WHEN edad=21 OR edad=22 OR edad=23 THEN SET categoria = 'Sub 22'  ;
        ELSE SET categoria = 'Sin categoria';
     END CASE ;
     INSERT INTO jugador(nombre, anio_nac, categoria) VALUES( nombre, anio_nac , categoria );
-- Cuando se termina de registrar al jugador, se devuelve una respuesta en formato de texto
     SET resultado = CONCAT( 'Jugador ', nombre, ' de ' , edad , ' años registrado en categoria [' , categoria, ']' );
END $
DELIMITER ;
Si deseas probar el procedimiento en MySQL puedes llamarlo de la siguiente forma
CALL registrar_jugador('Lani Hall',1990, @resultado);
select @resultado;
3. Ahora nos dirigemos a Netbeans.
Crea un nuevo proyecto «jcProc», no utilizaremos interfaz gráfica para no complicar el tutorial, añade la libreria *.jar de conexion JDBC y crea una nueva clase «database.java», el código para esta clase es:
package jcproc;
import java.sql.*;
/**
 * @web https://www.jc-mouse.net/
 * @author Mouse
 */
public class database {

  /* DATOS PARA LA CONEXION */
  private String bd = "BASE_DE_DATOS";
  private String login = "USUARIO";
  private String password = "PASSWORD";
  private String url = "jdbc:mysql://localhost/"+bd;
  private Connection conn = null;
//___________________________________________________________________________________ Soy una barra separadora 🙂
  //Constructor de la clase que se conecta a la base de datos una vez que se crea la instancia
  public database(){
      try{         
         Class.forName("com.mysql.jdbc.Driver");         
         conn = DriverManager.getConnection(url,login,password);         
      }catch(SQLException e){
         System.out.println(e);
      }catch(ClassNotFoundException e){
         System.out.println(e);
      }
    }
//___________________________________________________________________________________ Soy una barra separadora 🙂
/* FUNCION PARA LLAMAR A UN PROCEDIMIENTO ALMACENADO
 * INPUT:
 * nombre = tipo string
 * anio_nacimiento = tipo entero
 * OUTPUT:
 * String
 */
   public String procedure(String nombre, int anio_nacimiento)
   {
       String resultado=null;
       try {            
            // se crea instancia a procedimiento, los parametros de entrada y salida se simbolizan con el signo ?
            CallableStatement proc = conn.prepareCall(" CALL registrar_jugador(?,?,?) ");
            //se cargan los parametros de entrada
            proc.setString("nombre", nombre);//Tipo String
            proc.setInt("anio_nac", anio_nacimiento);//Tipo entero
            // parametros de salida
            proc.registerOutParameter("resultado", Types.VARCHAR);//Tipo String
            // Se ejecuta el procedimiento almacenado
            proc.execute();            
            // devuelve el valor del parametro de salida del procedimiento
            resultado = proc.getString("resultado");
        } 
       catch (Exception e) {                  
            System.out.println(e);
       }
       return resultado;
   }
//___________________________________________________________________________________ Soy una barra separadora 🙂
}
Esta clase esta dividida en dos partes, el constructor de la clase, donde realizamos la conexión a la base de datos y un metodo al que llamamos «procedure», este metodo es el que nos permite ejecutar el procedimiento almacenado en MySQL desde Java, esta comentado para que se pueda entender más facilmente.
4. para terminar implementados esta clase en el main.java, el código es:
package jcproc;
/**
 * @web https://www.jc-mouse.net/
 * @author Mouse
 */
public class Main {

    public static void main(String[] args) {

        database db = new database();

        String r = db.procedure("John Winston Lennon", 1999);
        System.out.println(r);

        r = db.procedure("James Paul McCartney", 1990);
        System.out.println(r);

        r = db.procedure("Ned Flanders", 1994);
        System.out.println(r);
    }

}
Finalmente ejecuta el proyecto en netbeans, debes tener como resultado:
Jugador John Winston Lennon de 13 años registrado en categoria [Sin categoria]
Jugador James Paul McCartney de 22 años registrado en categoria [Sub 22]
Jugador Ned Flanders de 18 años registrado en categoria [Sub 20]
Puedes bajarte el proyecto «procedimientos almacenados en java» desde aqui.

Tags

Si te ha gustado podrías compartirlo o dejar un comentario. ¡Muchas gracias!
Autor: JC Mouse

Yo soy yo :) JC Mouse, Soy orgullosamente boliviano soy fundador y CEO de la web jc-Mouse.net uno de las pocas web en emprendimiento y tecnología en Bolivia.

Toda la información que encuentres en este sitio es y sera completamente gratis siempre, puedes copiar, descargar y re-publicar si así lo deseas en otros blogs o sitios web, solo te pido a cambio que dejes una referencia a esta web. Esto nos ayuda a crecer y seguir aportando. Bye

Enjoy! :)

También Te Podría Interesar

HELP ME – Envía un SMS de auxilio con tu ubicación

HELP ME – Envía un SMS de auxilio con tu ubicación

HELP ME, es una aplicación android gratuita que te permite enviar un mensaje de auxilio (S.O.S.) hasta 4 personas que tu...

Utiliza 2 bases de datos diferentes en una aplicación parte I

Utiliza 2 bases de datos diferentes en una aplicación parte I

Cuando se desarrolla una aplicación, puede ser un requisito que este tenga soporte para varias tipos de base de datos, s...

Cambiar API Level en Android Studio

Cambiar API Level en Android Studio

Cuando desarrollamos aplicaciones en el IDE (Entorno de Desarrollo Integrado) de Android Studio, es importante indicar e...

MVC: Modelo, Vista y Controlador en PHP

MVC: Modelo, Vista y Controlador en PHP

EL patrón MVC (Model, View, Controller) o Modelo, Vista Controlador, es un tipo de diseño que separa en capas bien defin...

Hola Mundo con Firebase

Hola Mundo con Firebase

Firebase es la plataforma para el desarrollo de aplicaciones web y aplicaciones móviles de Google el cual se centra en e...

Introducción a MariaDB con Java

Introducción a MariaDB con Java

Maria DB  es un sistema de gestión de bases de datos derivado de MySQL con licencia GPL, pero con un rendimiento similar...

1 comentario en “Procedimientos almacenados en java”

  1. carmelosoft dice:

    ¡Hola!

    Estoy comenzando a programar en Java y bases de datos y cuando he comenzado a buscar información sobre como leer procedimientos almacenados desde java tu ejemplo ha sido el mas fácil de comprender, sencillo, claro y directo al grano. Gracias por haber dedicado ese tiempo, me ha sido de gran ayuda.

Los comentarios estan cerrados

Comparte lo que sabes

Categorias

Últimas entradas

Sourcetrail el explorador de código fuente de los lenguaje C, C ++, Java y Python se pasa al Software Libre y desde ahor...

Tapiti v1.2.0 es un Software Educativo Gratuito multiplataforma para los sistemas operativos Windows y Linux el cual no...

En este post vemos un ejemplo de como convertir un archivo de imagen JPG en un archivo PDF utilizando para ellos la libr...

El modelo Tweetbotornot es un algoritmo de aprendizaje automático que se entrenó en miles de cuentas reales de bot y no...

Herramientas

Generador de Enlaces a Whatsapp