HyperSQL DataBase (HSQLDB) es un moderno administrador de bases de datos relacionales, es portátil e implementado en java puro. Se puede incrustar con su aplicación java y también usar por separado. Es una base de datos muy pequeña que admite casi todas las características del sistema de base de datos estándar.
Entre sus características podemos mencionar:
En este post, nos conectaremos al servidor HSQLDB, crearemos una base de datos y realizaremos una consulta previa conexión desde una aplicación java.
Requisitos
Paso 1: Descargar HSQLDB
A la fecha de realizar este post, la ultima versión estable de HSQLDB es la 2.4.1 que funciona con el JDK 8, 9 y 10. Disponible en <Download HSQLDB>
Descarga el paquete y descomprime en algún lugar de tu disco duro. Los archivos que en encontraras son los siguientes:
Paso 2: Iniciar el Servidor y crear una base de datos
Abre una consola y ubícate en la carpeta «data», el comando necesario es:
java -classpath ../lib/hsqldb.jar org.hsqldb.server.Server --database.0 file:[ARCHIVO] --dbname.0 [ALIAS]
donde:
Por ejemplo:
java -classpath ../lib/hsqldb.jar org.hsqldb.server.Server --database.0 file:demo/demodb --dbname.0 demo
Creamos una base de datos con el nombre «demodb» en la carpeta «demo», su alias sera «demo». Tanto el nombre de la base de datos como su alias no necesariamente debe ser el mismo, aunque si lo prefieres así, no hay ningún problema.
Una vez ejecutado el comando se levantara el servidor junto a la base de datos en el puerto 9001. No cierres esta ventana, en cuanto la ventana se cierra el servidor también.
Paso 3: Database Manager
Database Manager es una herramienta de consulta de base de datos GUI simple con una visualización de árbol de las tablas.
Para iniciar el Administrador dirígete a la carpeta «lib» y ejecuta el archivo hsqldb.jar. A continuación se despliega una ventana de conexión donde debemos realizar algunos cambios.
Para terminar presiona [OK]
Si todo salio bien ya estas conectado a tu base de datos, pero este se encuentra vació, este administrador te permite llenar tu base de datos con tablas y datos ya preestablecidos ideal para realizar una prueba rápida. Para realizar esto:
Dirígete al menu Option -> Insert test data
Paso 4: Conexión y consulta a HSQLDB desde Java
Crea un proyecto java en Netbeans (o el IDE de tu preferencia) y añade el jar hsqldb.jar, es decir:
A continuación, modifica el Main de la siguiente manera:
import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement; /** * @see https://www.jc-mouse.net/ * @author mouse */ public class Main { static final String URL = "jdbc:hsqldb:hsql://localhost/demo"; static final String USUARIO = "SA"; static final String PASSWORD = ""; public static void main(String[] args) { try (Connection con = DriverManager.getConnection(URL, USUARIO, PASSWORD)) { Statement statement = con.createStatement(); ResultSet rs = statement.executeQuery("SELECT * FROM Customer"); while (rs.next()) { Long id = rs.getLong("ID"); String firstname = rs.getString("FIRSTNAME"); String lastname = rs.getString("LASTNAME"); String street = rs.getString("STREET"); String city = rs.getString("CITY"); System.out.println(String.format("%d | %s | %s | %s | %s", id, firstname, lastname, street, city)); } } catch (SQLException ex) { System.err.println(ex.getMessage()); } } }
ejecutando tenemos:
enjoy!!!
El índice TIOBE (TIOBE, The Importance of Being Earnest – «La importancia de ser honesto» – referencia a la[...]
Cuando realizamos un proyecto java utilizando fuentes de nuestro sistema, al momento de distribuir el programa y ejecuta[...]
JavaMail es una expansión de Java que facilita el envío y recepción de e-mail desde código java. JavaMail implementa el[...]
En este post vemos un ejemplo de como convertir un archivo de imagen JPG en un archivo PDF utilizando para ellos la libr[...]
En este tutorial personalizaremos un JTextField java para darle la apariencia de un TextBox de Windows Metro. El TextBox[...]
En este ejemplo tenemos un array en JSON el cual representa una lista de alumnos y queremos llevar este a una lista en j[...]