viernes, 19 de marzo de 2010

Java 6. Derby, la base de datos incluida en jdk 6

   Saludos compañeros y gracias por estar de nuevo aquí aprendiendo juntos un poco más sobre lo que es la tecnología Java en su última version de Java SE 6.

   Ahora le toca el turno a Derby: Base de datos relacional y transaccional que viene incluido por defecto en el JDK 6.0, más específicamente lo puede encontrar en la ruta de java. En windows: C:\Archivos de Programa\Java\jdk1.6.0\db, o en general en la carpera db donde se encuentra la instalación de java SE 6.

   Para hablar un poco de dónde viene Derby, esta se inicia como CloudSpace: una base de datos relacional creada por Informix, compañía que fue adquirida en 2001 por IBM. en 2004 IBM decide convertir a CloudSpace en software libre cambiando su nombre a Derby.
La página principal de Derby es: http://db.apache.org/derby/.

   Las ventajas que promete Derby son sus mínimas necesidades de configuración y administración y el pequeño espacio que ocupa en disco. Otra ventaja es que Derby soporta el almacenamiento de una base de datos archivada en un archivo JAR, lo que lo hace fácil de incluirlo y distribuirlo en nuestra aplicación.

   Visto esto, empecemos a ver cómo incluir esta base de datos en nuestra aplicación Java.

   Objetando un poco: Aunque se dice que Derby viene incluido con el JDK 6.0, en las últimas instalaciones que he realizado no ha sido instalado por defecto, por lo tanto lo descargué directamente de db-derby-10.5.3.0-bin.zip.

   Una vez descargado se descomprime en la carpeta que se desee (supongamos C:\derby). Ahora se agrega al PATH (variable de entorno) la ruta interna bin (es decir C:\derby\bin). En esta carpeta se encuentran dos archivos esenciales: ij.bat y startNetworkServer.bat. Abrimos una consola y ejecutamos primero el startNetworkServer.bat (en la ruta C:\derby\bin) con esto se levantará el servidor de base de datos Derby.

   Una vez hecho esto hay que dirigirse en una consola nueva a la carpeta de nuestro proyecto (preferiblemente) para crear nuestra base de datos nueva.
Una vez ubicado en la ruta de nuestro proyecto java se escribe ij.bat, se iniciará la aplicación ij que es la herramienta para conectarse, crear y manipular base de datos Derby.
NOTA IMPORTANTE: La creación de una base de datos Derby agrega una carpeta con el nombre de la base de datos al sistema en la ruta donde fue ejecutada la aplicación ij, por ello es recomendable dirigirse a la carpeta donde se encuentra nuestro proyecto y ejecutar allí esta herramienta.


C:\RutaProyecto\ij.bat
Version ij 10.5
ij>


   Ahora a la linea ij> se debe agregar algo como:

ij> connect 'jdbc:derby:NombreBD;create=true';



NOTA: No olvide colocar el punto y coma al final de cada sentencia derby, ya que esto indica que finaliza la misma, si no lo hace no se ejecuta la sentencia escrita.

   Con esto se crea una base de datos Derby de nombre NombreBD en la ruta donde se ejecutó el ij.bat. Podemos ahora crear una tabla, insertar registros y seleccionarlos:


ij> CREATE TABLE persona(id integer, nombre varchar(15), apellido varchar(15), edad integer);
0 filas insertadas/actualizadas/suprimidas
ij>INSERT INTO persona VALUES(1, 'Rafael', 'Romero', 31),(2, 'Orlando', 'Gracia', 42),(3, 'Yessica', 'Alba', 35);
3 filas insertadas/actualizadas/suprimidas
ij> SELECT * FROM persona;
//Se muestran los datos ingresados
3 filas seleccionadas


   Por defecto la ejecución automática está activada (autocommit ON), se puede controlar escribiendo en ij> autocommit ON; o autocommit OFF;

   Para salir de la herramienta ij se escribe exit;

   Una vez visto esto veamos como podemos enlazar esta base de datos a nuestra aplicación.
  1. import java.sql.*;
  2.  
  3. public class Derbiando {
  4.  
  5.         public static void main(String[] args) {
  6.                 Derbiando dbDerby = new Derbiando();
  7.                 dbDerby.mostrarDatos();
  8.         }
  9.  
  10.         public void mostrarDatos(){
  11.                 try{
  12.                         String driver = "org.apache.derby.jdbc.EmbeddedDriver";
  13.                         Class.forName(driver).newInstance();
  14.                         Connection conn = DriverManager.getConnection("jdbc:derby:C:\\RutaProyecto\\NombreBD");
  15.                         Statement s = conn.createStatement();
  16.                         ResultSet rs = s.executeQuery("SELECT * FROM persona");
  17.                         while(rs.next()){
  18.                                 System.out.println("id: "+rs.getInt(1));
  19.                                 System.out.println("nombre: "+rs.getString(2));
  20.                                 System.out.println("apellido: "+rs.getString(3));
  21.                                 System.out.println("edad: "+rs.getInt(4));
  22.                                 System.out.println();
  23.                         }
  24.                         rs.close();
  25.                         s.close();
  26.                         conn.close();
  27.                 }catch (Exception e) {
  28.                         e.printStackTrace();
  29.                 }
  30.                        
  31.                
  32.         }
  33. }



Salida Generada:
id: 1
nombre: Rafael
apellido: Romero
edad: 31

id: 2
nombre: Orlando
apellido: Gracia
edad: 42

id: 3
nombre: Yessica
apellido: Alba
edad: 35

2 comentarios:

Anónimo dijo...

Muchas gracias,me sirve bastante esta informacion.

ProgramerJP dijo...

muy bueno, me sirvió mucho, gracias por compartirlo