Bases de datos embebidas

  • No necesitan un servidor
  • Se inician y se apagan cuando abrimos y cerramos la aplicación
  • No utilizan “grandes cantidades de información”
  • No comparten datos
  • Van incluidas en el propio código del programa

SQLite

https://www.sqlite.org/download.html

Windows: https://www.sqlite.org/2020/sqlite-tools-win32-x86-3330000.zip

$ sqlite3 ex1
SQLite version 3.28.0 2019-03-02 15:25:24
Enter ".help" for usage hints.
sqlite> create table tbl1(one varchar(10), two smallint);
sqlite> insert into tbl1 values('hello!',10);
sqlite> insert into tbl1 values('goodbye', 20);
sqlite> select * from tbl1;
hello!|10
goodbye|20
sqlite>
sqlite> .help
.archive ...             Manage SQL archives
.auth ON|OFF             Show authorizer callbacks
.backup ?DB? FILE        Backup DB (default "main") to FILE
.bail on|off             Stop after hitting an error.  Default OFF
.binary on|off           Turn binary output on or off.  Default OFF
.cd DIRECTORY            Change the working directory to DIRECTORY
.changes on|off          Show number of rows changed by SQL
.check GLOB              Fail if output since .testcase does not match
.clone NEWDB             Clone data into NEWDB from the existing database
.databases               List names and files of attached databases
.dbconfig ?op? ?val?     List or change sqlite3_db_config() options
.dbinfo ?DB?             Show status information about the database
.dump ?TABLE?            Render database content as SQL
.echo on|off             Turn command echo on or off
.eqp on|off|full|...     Enable or disable automatic EXPLAIN QUERY PLAN
.excel                   Display the output of next command in spreadsheet
.exit ?CODE?             Exit this program with return-code CODE
.expert                  EXPERIMENTAL. Suggest indexes for queries
.explain ?on|off|auto?   Change the EXPLAIN formatting mode.  Default: auto
.filectrl CMD ...        Run various sqlite3_file_control() operations
.fullschema ?--indent?   Show schema and the content of sqlite_stat tables
.headers on|off          Turn display of headers on or off
.help ?-all? ?PATTERN?   Show help text for PATTERN
.import FILE TABLE       Import data from FILE into TABLE
.imposter INDEX TABLE    Create imposter table TABLE on index INDEX
.indexes ?TABLE?         Show names of indexes
.limit ?LIMIT? ?VAL?     Display or change the value of an SQLITE_LIMIT
.lint OPTIONS            Report potential schema issues.
.load FILE ?ENTRY?       Load an extension library
.log FILE|off            Turn logging on or off.  FILE can be stderr/stdout
.mode MODE ?TABLE?       Set output mode
.nullvalue STRING        Use STRING in place of NULL values
.once ?OPTIONS? ?FILE?   Output for the next SQL command only to FILE
.open ?OPTIONS? ?FILE?   Close existing database and reopen FILE
.output ?FILE?           Send output to FILE or stdout if FILE is omitted
.parameter CMD ...       Manage SQL parameter bindings
.print STRING...         Print literal STRING
.progress N              Invoke progress handler after every N opcodes
.prompt MAIN CONTINUE    Replace the standard prompts
.quit                    Exit this program
.read FILE               Read input from FILE
.recover                 Recover as much data as possible from corrupt db.
.restore ?DB? FILE       Restore content of DB (default "main") from FILE
.save FILE               Write in-memory database into FILE
.scanstats on|off        Turn sqlite3_stmt_scanstatus() metrics on or off
.schema ?PATTERN?        Show the CREATE statements matching PATTERN
.selftest ?OPTIONS?      Run tests defined in the SELFTEST table
.separator COL ?ROW?     Change the column and row separators
.sha3sum ...             Compute a SHA3 hash of database content
.shell CMD ARGS...       Run CMD ARGS... in a system shell
.show                    Show the current values for various settings
.stats ?on|off?          Show stats or turn stats on or off
.system CMD ARGS...      Run CMD ARGS... in a system shell
.tables ?TABLE?          List names of tables matching LIKE pattern TABLE
.testcase NAME           Begin redirecting output to 'testcase-out.txt'
.testctrl CMD ...        Run various sqlite3_test_control() operations
.timeout MS              Try opening locked tables for MS milliseconds
.timer on|off            Turn SQL timer on or off
.trace ?OPTIONS?         Output each SQL statement as it is run
.vfsinfo ?AUX?           Information about the top-level VFS
.vfslist                 List all available VFSes
.vfsname ?AUX?           Print the name of the VFS stack
.width NUM1 NUM2 ...     Set minimum column widths for columnar output
sqlite>

https://www.sqlite.org/cli.html

Apache Derby

  • Es una base de datos nativa escrita en Java
  • El núcleo y el driver ocupan menos de 3Mb
  • Aunque tiene modo cliente-servidor, se puede embeber en nuestra propia aplicación.
  • Es libre (licencia Apache).
  • Compatible con SQL estándar.

Para poder utilizar tranquilamente en nuestras aplicaciones el conector Derby, tendremos que hacer cambios en las variables de entorno: CLASSPATH.

C:\> SET DERBY_INSTALL=D:\db-derby-10.x.x.x-bin (siendo las x la versión actual del driver)
C:\>SET CLASSPATH = DERBY_INSTALL\lib\derby.jar;DERBY_INSTALL\lib\derbytools.jar;

Conectarse a una BBDD:

Ij>connect ‘jdbc:derby:D:\dirdb\Derby\ejemplo;create=true’;
CREATE TABLE alumnos (
id INT NOT NULL PRIMERY KEY,
nombre VARCHAR(25),
apellidos VARCHAR(50),
edad INT,
observaciones VARCHAR(200));

 

HyperSQL (OpenOffice)

HSQLDB : Hyperthreaded Structured Query Language Database

  • Sistema gestor de bases de datos libre
  • Escrito en Java.
  • Desde su versión 2.0, OpenOffice.org lo incluye para dar soporte Base.
  • Puede mantener la base de datos tanto en memoria como en ficheros en disco.
  • Tiene licencia BSD.

  • Ejecutamos desde la consola de comandos el archivo runManager.
  • Seleccionamos en el tipo de conexión , DataBaseEngine Standalone, y ahora es donde ponemos el path de la base de datos.
C:\hsqldb\bin\ runManager

Podemos ver que se ha creado una carpeta dentro de la subcarpeta data con el nombre prueba dentro de la carpeta de la ruta de conexión; prueba.

Desde el programa podemos:

  • CREAR BD
  • INSERTAR / BORRAR / CONSULTAR

H2 Database

  • H2 es un SGBDR programado en Java.
  • Puede ser incorporado en aplicaciones Java o ejecutarse en modo cliente-servidor.
  • Software de código libre bajo la Licencia Pública de Mozilla o la Eclipse Public License.

Actian NoSQL

Es una base de datos orientada a Objetos, anteriormente se llamaba DB4O (Database For Objets) pasando a ser una base de datos comercial para Java y .NET.

  • Orientada a objetos.
  • Disponible para entornos Java y .Net.
  • Dispone de licencia dual GPL (DB4O) / comercial (Actian).
  • Se evita el desfase objeto-relacional.
  • No utiliza el lenguaje SQL para el tratamiento y manipulación de los datos.

DB4O

  • Se instala mediante la inserción de un archivo .jar
  • Genera un único fichero, con extensión .YAP (entre 2GB y 256GB)
  • https://sourceforge.net/projects/db4o (Última actualización 2015-04-24)

Actian SQL

Otras bases de datos embebidas

  • Firebird de Google
    • Almacena y sincroniza datos con nuestra base de datos NoSQL alojada en la nube. Los datos se sincronizan con todos los clientes en tiempo real y se mantienen disponibles cuando la app no tiene conexión.

      Firebase Realtime Database es una base de datos alojada en la nube. Los datos se almacenan en formato JSON y se sincronizan en tiempo real con cada cliente conectado. Cuando compilas apps multiplataforma con nuestros SDK de plataformas de Apple, Android y JavaScript, todos tus clientes comparten una instancia de Realtime Database y reciben actualizaciones automáticamente con los datos más recientes.

  • SQL Server Mobile
  • Oracle Embedded

Puedes profundizar sobre Oracle a través de su canal de YouTube