Buscar este blog

jueves, 6 de junio de 2013

IF (SQL) Y CASE (SQL)

EJERCICIOS IF:
1- Inserta algunos registros:
insert into vehiculos (matricula,tipo,horallegada,horasalida)  values('ACD123','auto','8:30','9:40');
insert into vehiculos (matricula,tipo,horallegada,horasalida)  values('AKL098','auto','8:45','15:10');
insert into vehiculos (matricula,tipo,horallegada,horasalida)  values('HGF123','auto','9:30','18:40');
insert into vehiculos (matricula,tipo,horallegada,horasalida)  values('DRT123','auto','15:30',null);
insert into vehiculos (matricula,tipo,horallegada,horasalida)  values('FRT545','moto','19:45',null);
insert into vehiculos (matricula,tipo,horallegada,horasalida)  values('GTY154','auto','20:30','21:00');

2- Muestra la matricula, la hora de llegada y de salida de todos los vehículos, más una columna que calcule la cantidad de horas que estuvo cada vehículo en la playa, sin considerar los que aún no se fueron de la playa:


SELECT `matricula`,`horallegada`,`horasalida`,left(timediff(horasalida,horallegada),5) as horasminutos FROM `vehiculos`

3- Se cobra 1 euro por hora. Pero si un vehículo permanece en la playa 4 horas, se le cobran 3 euros, es decir, no se le cobra la cuarta hora; si está 8 horas, se cobran 6 euros, y así sucesivamente. Muestra la matricula, la hora de llegada y de salida de todos los vehículos, más la columna que calcule la cantidad de horas que estuvo cada vehículo en la playa (sin considerar los que aún no se fueron de la playa) y otra columna utilizando "if" que muestre la cantidad de horas gratis:

 select matricula,horallegada,horasalida,
  left(timediff(horasalida,horallegada),5) as horasminutos,
  if (hour(timediff(horasalida,horallegada))>4,
  hour(timediff(horasalida,horallegada)) div 4,0) as horagratis
  from vehiculos
  where horasalida is not null;

EJERCICIOS CASE:
select editorial, case count (*) where when 1 then 1 else 'mas de 1' end as 'cantidad' from libros group by editorial;
select ecitorial, case count (*) when 1 then 1 end as 'cantidad' from libros group by editorial;
select editorial, case count (*) when 1 then 1 when > 1 then 'mas de 1' end as 'cantidad' from libros group by editorial;
select editorial, case when count (*)=1 then 1 else 'mas de uno'end as cantidad from libros group by editorial;
select expediente, promedio, case when promedio<4 then 'suspendido' when promedio>4 and promedio and promedio<7 then 'bien' else 'notable' end as 'notas' from promedio;

No hay comentarios:

Publicar un comentario