Componente de Base de Datos
Componente de Base de Datos
Componente de Base de Datos
Actividad Práctica
El objetivo del Ciclo 3 es la construcción de un sistema de software que permita responder a los requerimientos
básicos de registro y autenticación en un banco, para esto el sistema estará compuesto por 3 capas (ver
imagen 1), una capa de datos llamada bank_db, que se encargará del almacenamiento de los datos, una
capa de back-end llamada bank_be, que se encargará del procesamiento y gestión de la información y una
capa de front-end llamada bank_fe, la cual será la interfaz con la que los usuarios interactuarán con el sistema.
A lo largo del ciclo se contextualizará, diseñará, desarrollará, probará y desplegará cada una de las capas,
siguiendo la estrategia bottom-up, la cual indica que primero se deben desarrollar los componentes de la capa
inferior (en este caso bank_db) y luego avanzar con los componentes de la siguiente capa (en este caso
bank_be), hasta llegar a los componentes de la capa superior (en este caso bank_fe)
Una base de datos es una colección de información organizada, usualmente almacenada electrónicamente
en un sistema computacional, su objetivo principal es brindar persistencia a información relevante en un
sistema. La base de datos es controlada por un sistema gestor de base de datos (Database Management
System o DBMS, por sus siglas en inglés), el cual funciona como un cliente entre el usuario final y la base de
pág 1 de 14
datos, y se encarga de administrar, entre otras cosas, los datos, el motor de la base de datos y el esquema
de la base de datos, para facilitar la organización y la manipulación de los datos. Gracias a los DBMS es
posible acceder, administrar, modificar, actualizar, controlar y organizar fácilmente los datos. Sin embargo,
existen muchos tipos distintos de DBMS que se encargan de estas operaciones a su manera, siguiendo
distintos paradigmas y esquemas. Así, el DBMS que utiliza una base de datos define su tipo y, por ende, el
motor que utiliza, el esquema que sigue para almacenar los datos, el lenguaje de dominio especifico que se
debe utilizar para dar instrucciones a la base de datos, entre otras cosas.
Existen dos tipos de bases de datos principales, relacionales y no relacionales, las bases de datos relacionales
son aquellas cuyo DBMS sigue un paradigma relacional. Es decir, que organizan los datos en una serie de
tablas con filas y columnas, donde cada columna es un atributo de la tabla, y cada fila es un registro. El
nombre relacional se debe a que pueden existir relaciones entre atributos de distintas tablas. Una base de
datos relacional se puede comparar con una tabla de Excel, sin embargo, esta es mucho más compleja.
En una base de datos relacional, las tablas se relacionan entre sí por medio de llaves primarias y foráneas.
Las llaves primarias son aquel atributo único que toda tabla tiene, es decir, son el atributo de una tabla en el
cual 2 filas no pueden tener el mismo valor. Generalmente la llave primaria de una tabla es el identificador (id)
de cada registro, y se utiliza para encontrar un registro especifico en la tabla. Por otro lado, las llaves foráneas
son las llaves primarias de una tabla almacenadas como atributos de otras tablas, esto tiene como propósito
formar relaciones entre las tablas. Por ejemplo, para indicar que una factura tiene un cliente asociado, en la
tabla Facturas se almacena la llave primaria (id) de dicho cliente.
pág 2 de 14
Generalmente, las bases de datos relacionales utilizan el lenguaje de consulta estructurado SQL para registrar
y consultar datos. Algunos de los DBMS más famosos que siguen este paradigma son PostgreSQL, MySQL,
MariaDB y Microsoft SQL Server. Para el componente de base de datos bank_db, se utilizará una base de
datos del DBMS PostgreSQL, este sistema brindará una base de datos relacional. En esta guía únicamente
se creará la base de datos, la generación del esquema se realizará en guías posteriores.
Ahora, si bien se podría desplegar la base de datos de manera local, teniendo en cuenta el propósito del
sistema, se realizará el despliegue en la nube, para ello, se utilizará Heroku, una Plataforma como Servicio o
PaaS (por sus siglas en inglés Platform as a Service) el cual brinda servicios de cómputo basados en la nube,
sin necesidad de administrar el hardware.
Para utilizar Heroku es necesario crear una cuenta, para ello se ingresa a la página oficial de Heroku
https://signup.heroku.com/ y se completa el formulario con la información solicitada:
Una vez pulsado el botón CREATE FREE ACOUNT se debe acceder al correo electrónico ingresado
anteriormente, donde se encontrará un correo de activación que contiene una URL a seguir:
pág 3 de 14
Allí se ingresa la contraseña de la cuenta y se indica si se desea recibir promociones de heroku por correo:
Una vez pulsado el botón SET PASSWORD AND LOGIN, se re-direcciona hacia otras dos páginas, una de
ellas para confirmar la creación de la cuenta, y la otra para aceptar los Términos de Servicio. Una vez se ha
hecho esto, se da por finalizada la creación de la cuenta Heroku, la cual se utilizará para realizar el despliegue
de las tres capas de la aplicación del caso de estudio del Ciclo 3.
pág 4 de 14
Despliegue de la base de datos PostgreSQL en Heroku
Allí se encuentra el Dashboard, es decir, el tablero donde se accede a las distintas aplicaciones asociadas a
la cuenta Heroku:
pág 5 de 14
Para desplegar una base de datos en Heroku, primero es necesario crear una aplicación. Esto se puede
realizar de dos formas, utilizando el botón New que se encuentra en la sección superior derecha del
Dashboard, o utilizando el botón Create new app si el Dashboard está vacío.
Para crear una aplicación únicamente se solicita el nombre que se le desea poner a esta. Dicho nombre
es único dentro de todo Heroku, razón por la cual se sugiere que sea altamente descriptivo.
pág 6 de 14
Luego de pulsar el botón Create app se mostrará la pestaña Deploy, donde se pueden observar las
funcionalidades que ofrece Heroku para el despliegue de la aplicación. Sin embargo, para desplegar
una base de datos en Heroku, se debe asignar un recurso de base de datos a la aplicación. Para ello,
se debe dirigir a la pestaña Resources.
Como su nombre lo indica, en esta pestaña se pueden añadir múltiples recursos a la aplicación, pero
en este caso solo se añadirá un recurso de base de datos. Para ello, se pulsa el botón Find more add-
ons:
pág 7 de 14
Esto redireccionará a la página donde se encuentran todos los recursos disponibles para la aplicación.
Allí se debe buscar y pulsar el recurso Heroku Postgres. Este se encuentra dentro de las primeras
opciones en la página:
Para instalar el recurso en la aplicación, se debe pulsar el botón Install Heroku Postgres:
pág 8 de 14
Esto redireccionará a otra página donde se debe seleccionar la aplicación en la cual se desea instalar
el recurso. Para ello se debe seleccionar el nombre de la aplicación y el plan Hobby Dev – Free, y
posteriormente pulsar Submit Order Form:
pág 9 de 14
El panel de control de la base de datos presenta bastante información, como las conexiones a esta, la
cantidad de información que almacena, su estado (Available), entre otros. La base de datos representa
la capa de datos del caso de estudio de este ciclo, lo que significa que la capa lógica hará uso de ella
para proveer sus funcionalidades. Por esta razón, es necesario obtener las credenciales de la base de
datos que permitirán a la capa lógica acceder a la base de datos. Para obtener estas credenciales se
debe dirigir a la pestaña Settings.
En la pestaña Settings aparecen algunas funcionalidades para eliminar la base de datos, se debe tener
cuidado con estas opciones. Para acceder a las credenciales se debe pulsar el botón View Credentials:
pág 10 de 14
Allí se mostrarán las credenciales de acceso a la base de datos, lo que incluye el Host, la Database, el
User, el Port y la Password. Todos estos valores son necesarios para establecer una conexión con la
base de datos.
Se debe recordar que estos valores son las credenciales de acceso a la base de datos, por cual se
debe tener precaución con compartirlos.
PostgreSQL al igual que la mayoría de los motores de bases de datos funcionan bajo el modelo Cliente
– Servidor, este modelo se basa en la existencia de un servidor que recibe, procesa y responde
peticiones a los clientes. Al realizar el despliegue de la base de datos en Heroku se creó dicho servidor.
Para enviar peticiones al servidor PostgreSQL y observar su estado, existen múltiples clientes con una
interfaz gráfica que lo permite. Para mostrar el funcionamiento de un cliente PostgreSQL, en esta guía
se utilizará TablePlus, un cliente sumamente ligero y de fácil acceso. A continuación, se describen los
pasos para la instalación del cliente de acuerdo con el sistema operativo:
pág 11 de 14
Instalación en Linux:
El proceso de instalación en Linux es bastante sencillo, pero se debe realizar desde consola ejecutando
los siguientes comandos:
sudo apt update && sudo apt upgrade
wget -O - -q http://deb.tableplus.com/apt.tableplus.com.gpg.key | sudo apt-key add –
sudo add-apt-repository "deb [arch=amd64] https://deb.tableplus.com/debian tableplus main"
sudo apt install tableplus
Uso de TablePlus
Para crear la conexión entre el cliente y el servidor, se debe abrir TablePlus y pulsar el botón Create a
new connection… que se encuentra en la parte inferior de la ventana:
pág 12 de 14
Allí se solicitará indicar el motor de la base de datos al que se desea conectar. En este caso
PostgreSQL:
Posteriormente, se solicitará un nombre para la conexión y las credenciales de la base de datos. Para
ello, se rellenan estos campos con los valores generados anteriormente por Heroku. La interfaz solicita
el ingreso de múltiples campos, pero solo es necesario ingresar los valores Host, Port, User, Password
y DataBase. Una vez se han ingresado los valores correctamente se inicia la conexión pulsando el botón
Connect:
pág 13 de 14
Una vez establecida la conexión con el servidor de la base de datos, se podrá ver los datos que este
contiene, sin embargo, actualmente no tiene información por lo cual solo se ve la pantalla vacía. A
medida se desarrolle el caso de estudio se podrá observar en el cliente como se agregan tablas y datos.
pág 14 de 14