Ver Mensaje Individual
  #7 (permalink)  
Antiguo 03/09/2012, 19:43
Avatar de gnzsoloyo
gnzsoloyo
Moderador criollo
 
Fecha de Ingreso: noviembre-2007
Ubicación: Actualmente en Buenos Aires (el enemigo ancestral)
Mensajes: 23.324
Antigüedad: 17 años
Puntos: 2658
Respuesta: Compo Finalizo este stored procedure con CASE Y WHEN???

Finalmente cuando llegué a casa pude revisar con más tranquilidad el problema y el tema es que estás confundiendo la sintaxis de CASE en MySQL con alguna otra:
Código MySQL:
Ver original
  1. DELIMITER $$
  2. DROP PROCEDURE IF EXISTS descontar_feriados $$
  3. CREATE PROCEDURE descontar_feriados (funCodigo VARCHAR (11), diasPedidos INT)
  4.  
  5.  
  6.     DECLARE feriado1, feriado2, resultado_fer1, resultado_fer2, resultado_intermedio INT;
  7.     SET feriado1=0;
  8.  
  9.     SELECT fer_1, fer_2 INTO feriado1, feriado2 FROM datos WHERE Fun_Codigo = funCodigo;
  10.     CASE
  11.         #feriado1 mayor q dias pedidos
  12.         WHEN feriado1>diasPedidos THEN
  13.             SET resultado_fer1= feriado1 - diasPedidos;
  14.             UPDATE datos SET fer_1 = resultado_fer1 WHERE Fun_Codigo= funCodigo;
  15.         #feriado1 igual q dias pedidos
  16.         WHEN feriado1 = diasPedidos THEN
  17.             SET resultado_fer1= feriado1 - diasPedidos;
  18.             UPDATE datos SET fer_1 = resultado_fer1 WHERE Fun_Codigo= funCodigo;
  19.         #feriado1 menor q dias pedidos
  20.         WHEN feriado1<diasPedidos THEN
  21.             SET resultado_fer1 = diasPedidos- feriado1 ;
  22.             SET resultado_intermedio = feriado2 - resultado_fer1;
  23.             UPDATE datos SET fer_ = 0 WHERE Fun_Codigo= funCodigo;
  24.             UPDATE datos SET fer_2 = resultado_intermedio WHERE Fun_Codigo= funCodigo;
  25.         #feriado2 mayor q dias pedidos
  26.         WHEN feriado1 = 0 and feriado2> diasPedidos THEN
  27.             SET resultado_fer2 = feriado2 - diasPedidos;
  28.             UPDATE datos SET fer_2 = resultado_fer2 WHERE Fun_Codigo= funCodigo;
  29.         #feriado2 igual q dias pedidos
  30.         WHEN feriado2 = diasPedidos THEN
  31.             SET resultado_fer2 = feriado2 - diasPedidos;
  32.             UPDATE datos SET fer_2 = resultado_fer2 WHERE Fun_Codigo= funCodigo;
  33.         WHEN feriado1<=0 and feriado2 <= 0 then
  34.             UPDATE datos SET fer_1 = 0, fer_2 = 0 WHERE Fun_Codigo= funCodigo;
  35.     END CASE;
__________________
¿A quién le enseñan sus aciertos?, si yo aprendo de mis errores constantemente...
"El problema es la interfase silla-teclado." (Gillermo Luque)