viernes, 25 de octubre de 2019

Diferencias SQL en MySQL, SQL Server, Oracle, PostgreSQL y SQLite

Veremos un diagrama EER de dos tablas y como se realizan las declaraciones de las mismas en los distintos gestores de bases de datos:

  • MySql y MariaBD
  • Oracle
  • SQL Server
  • PostgreSQL
  • SQLite


MySql y MariaBD

  1. CREATE TABLE IF NOT EXISTS inquilinos (
  2. id INT NOT NULL AUTO_INCREMENT,
  3. dni VARCHAR(8) NOT NULL,
  4. nombres VARCHAR(150) NOT NULL,
  5. paterno VARCHAR(150) NOT NULL,
  6. materno VARCHAR(150) NOT NULL,
  7. telefono VARCHAR(40) NULL,
  8. correo VARCHAR(200) NULL,
  9. deuda DECIMAL(10,2) NOT NULL,
  10. fecha_ingreso DATE NOT NULL,
  11. PRIMARY KEY (idinquilinos),
  12. UNIQUE INDEX dni_UNIQUE (dni ASC),
  13. UNIQUE INDEX correo_UNIQUE (correo ASC))
  14. ENGINE = InnoDB
  15. DEFAULT CHARACTER SET = utf8;
  16. INSERT INTO inquilinos(dni, nombres, paterno, materno,
  17. telefono, fecha_ingreso, correo, deuda) VALUES
  18. ('31378082','LUISA', 'PAUCAR','NARRO','999888777',
  19. '2018-01-28','lpaucar@mail.com',0.00),
  20. ('43331042','AUGUSTO','SOTOMAYOR','NARVAJO','900800700',
  21. '2019-10-08','asoto@mail.com',0.00);
  22. SELECT * FROM inquilinos


Oracle



SQL Server

  1. CREATE TABLE inquilinos (
  2. id INT NOT NULL IDENTITY(1,1) PRIMARY KEY,
  3. dni VARCHAR(8) UNIQUE NOT NULL,
  4. nombres VARCHAR(150) NOT NULL,
  5. paterno VARCHAR(150) NOT NULL,
  6. materno VARCHAR(150) NOT NULL,
  7. telefono VARCHAR(40) NULL,
  8. correo VARCHAR(200) UNIQUE NOT NULL,
  9. deuda MONEY NOT NULL,
  10. fecha_ingreso DATE NOT NULL DEFAULT CURRENT_TIMESTAMP
  11. );
  12. INSERT INTO [inquilinos] ([dni],[nombres],[paterno],
  13. [materno],[telefono],[correo],[deuda],[fecha_ingreso]
  14. ) VALUES
  15. ('31378082','LUISA', 'PAUCAR','NARRO','999888777',
  16. 'lpaucar@mail.com',0.00,'2018-01-28'),
  17. ('43331042','AUGUSTO','SOTOMAYOR','NARVAJO','900800700',
  18. 'asoto@mail.com',0.00,'2019-10-08');
  19. SELECT * FROM inquilinos


PostgreSQL

  1. CREATE TABLE public."Usuarios"
  2. (
  3. id serial NOT NULL,
  4. dni character(8) NOT NULL,
  5. nombres character varying(100) NOT NULL,
  6. apellidos character varying(150) NOT NULL,
  7. fecha_nacimiento date NOT NULL,
  8. PRIMARY KEY (id)
  9. )
  10. WITH (
  11. OIDS = FALSE
  12. );
  13. ALTER TABLE public."Usuarios"
  14. OWNER to postgres;
  15. INSERT INTO Usuarios(
  16. dni, nombres, apellidos, fecha_nacimiento)
  17. VALUES ('71700011', 'Alan Damian', 'Toledo Higuchi', '1990-10-01');


SQLite

lunes, 21 de octubre de 2019

Creando una vista en MySQL

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:

  1. SELECT
  2. pagos.idpagos,
  3. inquilinos.dni,
  4. CONCAT_WS(" ", inquilinos.nombres, inquilinos.paterno, inquilinos.materno),
  5. pagos.monto
  6. DATE(pagos.fecha),
  7. TIME(pagos.fecha)
  8. FROM pagos INNER JOIN inquilinos
  9. 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:

  1. SELECT
  2. pagos.idpagos id,
  3. inquilinos.dni dni,
  4. CONCAT_WS(" ", inquilinos.nombres, inquilinos.paterno, inquilinos.materno) datos,
  5. pagos.monto monto
  6. DATE(pagos.fecha) fecha,
  7. TIME(pagos.fecha) hora
  8. FROM pagos INNER JOIN inquilinos
  9. ON pagos.inquilino = inquilinos.idinquilinos


Ahora podemos proceder a crear la vista anteponiendo lo siguiente: "CREATE VIEW ________ AS" de la siguiente manera

  1. CREATE VIEW pagos_view AS
  2. SELECT
  3. pagos.idpagos id,
  4. inquilinos.dni dni,
  5. CONCAT_WS(" ", inquilinos.nombres, inquilinos.paterno, inquilinos.materno) datos,
  6. pagos.monto monto,
  7. DATE(pagos.fecha) fecha,
  8. TIME(pagos.fecha) hora
  9. FROM pagos INNER JOIN inquilinos
  10. 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

  1. 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

Creando una tabla con clave foránea en MySQL

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. Si quieres el código SQL de la tabla "inquilinos" has clic aquí


Código SQL

El código resultante será el siguiente:

  1. CREATE TABLE IF NOT EXISTS pagos (
  2. idpagos INT NOT NULL AUTO_INCREMENT,
  3. inquilino INT NOT NULL,
  4. monto DECIMAL(10,2) NOT NULL,
  5. fecha DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
  6. PRIMARY KEY (idpagos),
  7. CONSTRAINT fk_pago_inquilino
  8. FOREIGN KEY (inquilino)
  9. REFERENCES inquilinos (idinquilinos)
  10. ON DELETE NO ACTION
  11. ON UPDATE NO ACTION
  12. )ENGINE = InnoDB
  13. DEFAULT CHARACTER SET = utf8;


  • El campo "inquilino" sera nuestra clave foránea, lo que significa que estará vinculado a la tabla "inquilinos", de tal manera que para agregar un pago, primero debemos tener por lo menos un inquilino, ya que el campo es "NOT NULL".
  • La clave "fk_pago_inquilino" es el nombre de la clave foránea debe ser única, lo que implica que no se podrá repetir este nombre en ningún campo o nombre de relación de esta base de datos.
  • Se usa las siguientes sentencias:
    • ON DELETE NO ACTION: Implica que si se desea eliminar un registro de "inquilinos" que tenga por lo menos un pago, saltará un error y no dejará borrarlo.
    • ON UPDATE NO ACTION: Implica que si se desea actualizar la clave primaria de un registro de "inquilinos" que tenga por lo menos un pago, saltará un error y no dejará cambiar la clave, pero ¿Por qué querríamos hacer eso?
  • ENGINE = InnoDB, nos garantiza que podremos utilizar claves foráneas y soporte del "commit" y "rollback"
  • DEFAULT CHARACTER SET = utf8; nos permite ingresar caracteres especiales como la "ñ" o vocales tildadas a nuestros registros.


Insertando datos de prueba

  1. INSERT INTO pagos(inquilino, monto, fecha)
  2. VALUES (1,400,CURRENT_TIMESTAMP),
  3. (2,300,"2019-10-18 18:30:00");

  • En el caso del campo "fecha", se emplea en el primer caso "CURRENT_TIMESTAMP" que devuelve la fecha y hora actual para el servidor MySQL, en el segundo caso se especifica la fecha y hora en el formato "YYYY-MM-DD HH:MM:SS".


viernes, 11 de octubre de 2019

Creando una tabla en MySQL

Diagrama EER

En este ejemplo vamos a implementar el código SQL para MySQL de la siguiente tabla que tenemos según el diagrama EER


Código SQL

El código resultante será el siguiente:

  1. CREATE TABLE IF NOT EXISTS inquilinos (
  2. idinquilinos INT NOT NULL AUTO_INCREMENT,
  3. dni VARCHAR(8) NOT NULL,
  4. nombres VARCHAR(150) NOT NULL,
  5. paterno VARCHAR(150) NOT NULL,
  6. materno VARCHAR(150) NOT NULL,
  7. telefono VARCHAR(40) NULL,
  8. correo VARCHAR(200) NULL,
  9. deuda DECIMAL(10,2) NOT NULL,
  10. fecha_ingreso DATE NOT NULL,
  11. PRIMARY KEY (idinquilinos),
  12. UNIQUE INDEX dni_UNIQUE (dni ASC))
  13. ENGINE = InnoDB
  14. DEFAULT CHARACTER SET = utf8;


  • El campo "idinquilinos" sera "AUTO_INCREMENT", lo que significa que iniciará en 1 y cada registro que se inserte generará automáticamente un nuevo valor sin que necesitemos especificarlo. Al ser un dato numérico simple y no un código se obtiene mayor velocidad en consultas a la base de datos.
  • El campo "idinquilinos" sera "PRIMARY KEY", lo que implica que será la clave primaria es decir cada registro tendrá un único identificador que es este campo y nos servirá para realizar búsquedas o emplearlo como referencias para claves foráneas a otras tablas.
  • El campo "dni" es de tipo "UNIQUE", lo que implica que no se podrá repetir este valor en ningún registro de esta tabla.
  • ENGINE = InnoDB, nos garantiza que podremos utilizar claves foráneas y soporte del "commit" y "rollback"
  • DEFAULT CHARACTER SET = utf8; nos permite ingresar caracteres especiales como la "ñ" o vocales tildadas a nuestros registros.


Insertando datos de prueba

  1. INSERT INTO inquilinos(dni, nombres, paterno, materno,
  2. telefono, fecha_ingreso, correo, deuda) VALUES
  3. ('31378082','LUISA', 'PAUCAR','NARRO','999888777',
  4. '2018-01-28','lpaucar@mail.com',0.00),
  5. ('43331042','AUGUSTO','SOTOMAYOR','NARVAJO','900800700',
  6. '2019-10-08','asoto@mail.com',0.00);