111 - Lenguaje de control de flujo (if)


Problema:

Trabajamos con la tabla "libro" de una librería.
Eliminamos la tabla si existe:

 if object_id('libros') is not null
  drop table libros;

Creamos la tabla:

 create table libros(
  codigo int identity,
  titulo varchar(40) not null,
  autor varchar(30),
  editorial varchar(20),
  precio decimal(5,2),
  cantidad tinyint,
  primary key (codigo)
 );

Ingresamos los siguientes registros:

 insert into libros values('Uno','Richard Bach','Planeta',15,100);
 insert into libros values('El aleph','Borges','Emece',20,150);
 insert into libros values('Aprenda PHP','Mario Molina','Nuevo siglo',50,200);
 insert into libros values('Alicia en el pais de las maravillas','Lewis Carroll','Emece',15,0);
 insert into libros values('Java en 10 minutos','Mario Molina','Emece',40,200);

Mostramos los títulos de los cuales no hay libros disponibles (cantidad=0); en caso que no haya, mostramos un mensaje:

 if exists (select *from libros where cantidad=0)
  (select titulo from libros where cantidad=0)
 else
  select 'No hay libros sin stock';

Hacemos un descuento del 10% a todos los libros de editorial "Emece"; si no hay, mostramos un mensaje:

 if exists (select *from libros where editorial='Emece')
 begin
  update libros set precio=precio-(precio*0.1) where editorial='Emece'
  select 'libros actualizados'
 end
 else
  select 'no hay registros actualizados';

Veamos si se actualizaron:

 select *from libros where editorial='Emece';

Eliminamos los libros de los cuales no hay stock (cantidad=0); si no hay, mostramos un mensaje:

 if exists (select *from libros where cantidad=0)
  delete from libros where cantidad=0
 else
  select 'No hay registros eliminados';

Se eliminó un registro, se ejecutó la sentencia del "if" porque había registros que cumplían la condición.

Ejecutamos nuevamente la sentencia anterior:

 if exists (select *from libros where cantidad=0)
  delete from libros where cantidad=0
 else
  select 'No hay registros eliminados';

Ahora se ejecutó la sentencia del "else" porque no había registros que cumplieran la condición.




Retornar