Diagrama EER
En este ejemplo vamos a implementar el código SQL para MySQL de la siguientes tablas que tenemos según el diagrama EER:
Lo que deseamos es crear una vista, esta vista actúa como una tabla que nosotros podemos personalizar a partir de consultas SELECT, son muy útiles para representar información de dos o más tablas que se relacionan en una sola. Ojo una vista no es una tabla propiamente dicha y solo se le puede aplicar SELECT, es decir solo ver sus datos, no se puede agregar, actualizar o eliminar registros de una vista, estos son registros de sus respectivas tablas y ahí se deben ejecutar dichas sentencias
Código SQL
Primero debemos tener la consulta que deseamos convertir en una vista, en este caso relacionar un pago con un inquilino, de forma que yo pueda ver el código del pago, el DNI del inquilino, sus nombres y apellidos en un solo campo, el pago que realizo, la fecha y hora (por separado) que lo hizo. El código resultante será el siguiente:
SELECT
pagos.idpagos,
inquilinos.dni,
CONCAT_WS(" ", inquilinos.nombres, inquilinos.paterno, inquilinos.materno),
pagos.monto
DATE(pagos.fecha),
TIME(pagos.fecha)
FROM pagos INNER JOIN inquilinos
ON pagos.inquilino = inquilinos.idinquilinos
- La función "CONCAT_WS" nos permite concatenar dos o más campos, indicando como primer parámetro el caracter de separación, en este caso el espacio en blanco (" ").
- Podemos extraer la fecha de un DATETIME con la función YEAR.
- Podemos extraer la hora de un DATETIME con la función TIME.
Ahora debemos asignar un "alias" a cada campo para tener un mejor orden:
SELECT
pagos.idpagos id,
inquilinos.dni dni,
CONCAT_WS(" ", inquilinos.nombres, inquilinos.paterno, inquilinos.materno) datos,
pagos.monto monto
DATE(pagos.fecha) fecha,
TIME(pagos.fecha) hora
FROM pagos INNER JOIN inquilinos
ON pagos.inquilino = inquilinos.idinquilinos
Ahora podemos proceder a crear la vista anteponiendo lo siguiente: "
CREATE VIEW ________ AS" de la siguiente manera
CREATE VIEW pagos_view AS
SELECT
pagos.idpagos id,
inquilinos.dni dni,
CONCAT_WS(" ", inquilinos.nombres, inquilinos.paterno, inquilinos.materno) datos,
pagos.monto monto,
DATE(pagos.fecha) fecha,
TIME(pagos.fecha) hora
FROM pagos INNER JOIN inquilinos
ON pagos.inquilino = inquilinos.idinquilinos
- El nombre de la vista es "pagos_view".
- Podemos aplicarle consultas SELECT donde el nombre de los campos son los "alias" que le elegimos.
Probando
SELECT * FROM pagos_view;
Nos debe devolver algo así:
id |
dni
|
datos
|
monto
|
fecha
|
hora
|
1
|
31378082
|
LUISA PAUCAR NARRO
|
400.00
|
2019-10-21
|
21:34:35
|
2
|
43331042
|
AUGUSTO SOTOMAYOR NARVAJO
|
300.00
|
2019-10-18
|
18:30:00
|