55 - Combinar más de 2 tablas


Problema:

Una librería almacena la información de sus libros para la venta en tres tablas, "libros", "autores" y "editoriales".

Eliminamos ambas tablas y las creamos:

  drop table libros;
  drop table autores;
  drop table editoriales;

 create table libros(
  codigo number(5),
  titulo varchar2(40),
  codigoautor number(4) not null,
  codigoeditorial number(3),
  primary key(codigo)
 );

 create table autores(
  codigo number(4),
  nombre varchar2(20),
  primary key (codigo)
 );

 create table editoriales(
  codigo number(3),
  nombre varchar2(20),
  primary key (codigo)
 );

Ingresamos algunos registros:

 insert into editoriales values(1,'Planeta');
 insert into editoriales values(2,'Emece');
 insert into editoriales values(3,'Siglo XXI');
 insert into editoriales values(4,'Norma');
 
 insert into autores values (1,'Richard Bach');
 insert into autores values (2,'Borges');
 insert into autores values (3,'Jose Hernandez');
 insert into autores values (4,'Mario Molina');
 insert into autores values (5,'Paenza');
 
 insert into libros values(100,'El aleph',2,2);
 insert into libros values(101,'Martin Fierro',3,1);
 insert into libros values(102,'Aprenda PHP',4,3);
 insert into libros values(103,'Uno',1,1);
 insert into libros values(104,'Java en 10 minutos',0,3);
 insert into libros values(105,'Matematica estas ahi',10,null);
 insert into libros values(106,'Java de la A a la Z',4,0);

Recuperamos todos los datos de los libros consultando las tres tablas:

 select titulo,a.nombre as autor,e.nombre as editorial
  from autores a
  join libros l
  on codigoautor=a.codigo
  join editoriales e
  on codigoeditorial=e.codigo;

Note que no aparecen los libros cuyo código de autor no se encuentra en "autores" (caso de "Java en 10 minutos" y "Matematica estas ahi") y cuya editorial no existe en "editoriales" (caso de "Matematica estas ahi" y "Java de la A a la Z"), esto es porque realizamos una combinación interna.

Podemos combinar varios tipos de join en una misma sentencia:

 select titulo,a.nombre as autor,e.nombre as editorial
  from autores a
  right join libros l
  on codigoautor=a.codigo
  left join editoriales e
  on codigoeditorial=e.codigo;

Ingresemos el siguiente lote de comandos en el Oracle SQL Developer:

 drop table libros;
 drop table autores;
 drop table editoriales;

 create table libros(
  codigo number(5),
  titulo varchar2(40),
  codigoautor number(4) not null,
  codigoeditorial number(3),
  primary key(codigo)
 );

 create table autores(
  codigo number(4),
  nombre varchar2(20),
  primary key (codigo)
 );

 create table editoriales(
  codigo number(3),
  nombre varchar2(20),
  primary key (codigo)
 );

 insert into editoriales values(1,'Planeta');
 insert into editoriales values(2,'Emece');
 insert into editoriales values(3,'Siglo XXI');
 insert into editoriales values(4,'Norma');
 
 insert into autores values (1,'Richard Bach');
 insert into autores values (2,'Borges');
 insert into autores values (3,'Jose Hernandez');
 insert into autores values (4,'Mario Molina');
 insert into autores values (5,'Paenza');
 
 insert into libros values(100,'El aleph',2,2);
 insert into libros values(101,'Martin Fierro',3,1);
 insert into libros values(102,'Aprenda PHP',4,3);
 insert into libros values(103,'Uno',1,1);
 insert into libros values(104,'Java en 10 minutos',0,3);
 insert into libros values(105,'Matematica estas ahi',10,null);
 insert into libros values(106,'Java de la A a la Z',4,0);

 select titulo,a.nombre as autor,e.nombre as editorial
  from autores a
  join libros l
  on codigoautor=a.codigo
  join editoriales e
  on codigoeditorial=e.codigo;

 select titulo,a.nombre as autor,e.nombre as editorial
  from autores a
  right join libros l
  on codigoautor=a.codigo
  left join editoriales e
  on codigoeditorial=e.codigo;

La ejecución de este lote de comandos SQL genera una salida similar a:

SQL Developer combinación de más de dos tablas


Retornar