34 - Clave primaria compuesta


Primer problema:

Un consultorio médico en el cual trabajan 3 médicos registra las consultas de los pacientes en una tabla llamada "consultas".

1- Elimine la tabla:

  drop table consultas;

2- La tabla contiene los siguientes datos:

  - fechayhora: date not null, fecha y hora de la consulta,
  - medico: varchar2(30), not null, nombre del médico (Perez,Lopez,Duarte),
  - documento: char(8) not null, documento del paciente,
  - paciente: varchar2(30), nombre del paciente,
  - obrasocial: varchar2(30), nombre de la obra social (IPAM,PAMI, etc.).

3- Setee el formato de "date" para que nos muestre día, mes, año, hora y minutos:

 ALTER SESSION SET NLS_DATE_FORMAT = 'DD/MM/YYYY HH24:MI';

4- Un médico sólo puede atender a un paciente en una fecha y hora determinada. En una fecha y hora determinada, varios médicos atienden a distintos pacientes. Cree la tabla definiendo una clave primaria compuesta:

 create table consultas(
  fechayhora date not null,
  medico varchar2(30) not null,
  documento char(8) not null,
  paciente varchar2(30),
  obrasocial varchar2(30),
  primary key(fechayhora,medico)
 );

4- Ingrese varias consultas para un mismo médico en distintas horas el mismo día:

 insert into consultas
  values ('05/11/2006 8:00','Lopez','12222222','Acosta Betina','PAMI');
 insert into consultas
  values ('05/11/2006 8:30','Lopez','23333333','Fuentes Carlos','PAMI');

5- Ingrese varias consultas para diferentes médicos en la misma fecha y hora:

 insert into consultas
  values ('05/11/2006 8:00','Perez','34444444','Garcia Marisa','IPAM');
 insert into consultas
  values ('05/11/2006 8:00','Duarte','45555555','Pereyra Luis','PAMI');

6- Intente ingresar una consulta para un mismo médico en la misma hora el mismo día (mensaje de error)

7- Intente cambiar la hora de la consulta de "Acosta Betina" por una no disponible ("8:30") (error)

8- Cambie la hora de la consulta de "Acosta Betina" por una disponible ("9:30")

9- Ingrese una consulta para el día "06/11/2006" a las 10 hs. para el doctor "Perez"

10- Recupere todos los datos de las consultas de "Lopez" (3 registros)

11- Recupere todos los datos de las consultas programadas para el "05/11/2006 8:00" (2 registros)

12- Muestre día y mes de todas las consultas de "Lopez"

Ver solución

  drop table consultas;

 ALTER SESSION SET NLS_DATE_FORMAT = 'DD/MM/YYYY HH24:MI';

 create table consultas(
  fechayhora date not null,
  medico varchar2(30) not null,
  documento char(8) not null,
  paciente varchar2(30),
  obrasocial varchar2(30),
  primary key(fechayhora,medico)
 );

 insert into consultas
  values ('05/11/2006 8:00','Lopez','12222222','Acosta Betina','PAMI');
 insert into consultas
  values ('05/11/2006 8:30','Lopez','23333333','Fuentes Carlos','PAMI');

 insert into consultas
  values ('05/11/2006 8:00','Perez','34444444','Garcia Marisa','IPAM');
 insert into consultas
  values ('05/11/2006 8:00','Duarte','45555555','Pereyra Luis','PAMI');

 insert into consultas
  values ('05/11/2006 8:00','Perez','25555555','Mercado Marcos','PAMI');

 update consultas set fechayhora='05/11/2006 8:30' where paciente='Acosta Betina';

 update consultas set fechayhora='05/11/2006 9:30' where paciente='Acosta Betina';

 insert into consultas
  values ('06/11/2006 10:00','Lopez','25555555','Mercado Marcos','PAMI');

 select *from consultas
  where medico='Lopez';

 select *from consultas
  where fechayhora='05/11/2006 8:00';

 select extract(day from fechayhora) as dia,
  extract(month from fechayhora) as mes
  from consultas
  where medico='Lopez';

 

Segundo problema:

Un club dicta clases de distintos deportes. En una tabla llamada "inscriptos" almacena la información necesaria.

1- Elimine la tabla "inscriptos":

  drop table inscriptos;

2- La tabla contiene los siguientes campos:

 - documento del socio alumno: char(8) not null
 - nombre del socio: varchar2(30),
 - nombre del deporte (tenis, futbol, natación, basquet): varchar2(15) not null,
 - año de inscripcion: date,
 - matrícula: si la matrícula ha sido o no pagada ('s' o 'n').

3- Necesitamos una clave primaria que identifique cada registro. Un socio puede inscribirse en varios deportes en distintos años. Un socio no puede inscribirse en el mismo deporte el mismo año. Varios socios se inscriben en un mismo deporte en distintos años. Cree la tabla con una clave compuesta:

 create table inscriptos(
  documento char(8) not null, 
  nombre varchar2(30),
  deporte varchar2(15) not null,
  año date,
  matricula char(1),
  primary key(documento,deporte,año)
 );

4- Setee el formato de "date" para que nos muestre solamente el año (no necesitamos las otras partes de la fecha ni la hora)

5- Inscriba a varios alumnos en el mismo deporte en el mismo año:

 insert into inscriptos
  values ('12222222','Juan Perez','tenis','2005','s');
 insert into inscriptos
  values ('23333333','Marta Garcia','tenis','2005','s');
 insert into inscriptos
  values ('34444444','Luis Perez','tenis','2005','n');

6- Inscriba a un mismo alumno en varios deportes en el mismo año:

 insert into inscriptos
  values ('12222222','Juan Perez','futbol','2005','s');
 insert into inscriptos
  values ('12222222','Juan Perez','natacion','2005','s');
 insert into inscriptos
  values ('12222222','Juan Perez','basquet','2005','n');

7- Ingrese un registro con el mismo documento de socio en el mismo deporte en distintos años:

 insert into inscriptos
  values ('12222222','Juan Perez','tenis','2006','s');
 insert into inscriptos
  values ('12222222','Juan Perez','tenis','2007','s');

8- Intente inscribir a un socio alumno en un deporte en el cual ya esté inscripto en un año en el cual ya se haya inscripto (mensaje de error)

9- Intente actualizar un registro para que la clave primaria se repita (error)

10- Muestre los nombres y años de los inscriptos en "tenis" (5 registros)

11- Muestre los nombres y deportes de los inscriptos en el año 2005 (6 registros)

12- Muestre el deporte y año de todas las inscripciones del socio documento "12222222" (6 registros)


Ver solución
  drop table inscriptos;

 create table inscriptos(
  documento char(8) not null, 
  nombre varchar2(30),
  deporte varchar2(15) not null,
  año date,
  matricula char(1),
  primary key(documento,deporte,año)
 );

 ALTER SESSION SET NLS_DATE_FORMAT = 'YYYY';

 insert into inscriptos
  values ('12222222','Juan Perez','tenis','2005','s');
 insert into inscriptos
  values ('23333333','Marta Garcia','tenis','2005','s');
 insert into inscriptos
  values ('34444444','Luis Perez','tenis','2005','n');

 insert into inscriptos
  values ('12222222','Juan Perez','futbol','2005','s');
 insert into inscriptos
  values ('12222222','Juan Perez','natacion','2005','s');
 insert into inscriptos
  values ('12222222','Juan Perez','basquet','2005','n');

 insert into inscriptos
  values ('12222222','Juan Perez','tenis','2006','s');
 insert into inscriptos
  values ('12222222','Juan Perez','tenis','2007','s');

 insert into inscriptos
  values ('12222222','Juan Perez','tenis','2005','s');

 update inscriptos set deporte='tenis'
  where documento='12222222' and
  deporte='futbol' and
  año='2005';

 select nombre,año from inscriptos
  where deporte='tenis';

 select nombre,deporte from inscriptos
  where año='2005';

 select deporte,año from inscriptos
  where documento='12222222';

Retornar