Foros del Web » Programación para mayores de 30 ;) » Bases de Datos General » Mysql »

Problema con Triggers en MySQL

Estas en el tema de Problema con Triggers en MySQL en el foro de Mysql en Foros del Web. Hola soy nuevo en el foro y es mi primero de muchos post...tengo un problema al momento de crear un Trigger en mi base de ...
  #1 (permalink)  
Antiguo 02/09/2008, 09:51
 
Fecha de Ingreso: septiembre-2008
Mensajes: 3
Antigüedad: 15 años, 7 meses
Puntos: 0
Exclamación Problema con Triggers en MySQL

Hola soy nuevo en el foro y es mi primero de muchos post...tengo un problema al momento de crear un Trigger en mi base de datos..
he leivo varios tutoriales donde explican la creacion de los triggers para mysql..
lo hago exactamente con la sintaxys que me da.. ( obvio que con mis parametros necesarios ) y me da el sig. error apesar de cambiar de manera para generar mi Trigger..
acontinuacion mi codigo y error:

CREATE TRIGGER trigger_cambios BEFORE UPDATE ON componentes FOR EACH ROW BEGIN INSERT INTO cambios( componenteviejo, componentenuevo, usuario, fecha_cambio ) VALUES (OLD.num_serie, NEW.num_serie, NEW.id_persona, NOW( ) );

Error:
MySQL ha dicho:

#1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '' at line 5

lo hago directamente de consola.. y desde phpmyadmin y me dice lo mismo.
si alguien me puede ayudar.. se lo agradeceria bastante..


Saludos..

PD: ya tengo la tabla cambios de donde guardare el trigger y la tabla componentes tambien.. que es de donde monitoriare los updates...
  #2 (permalink)  
Antiguo 02/09/2008, 11:20
Avatar de gnzsoloyo
Moderador criollo
 
Fecha de Ingreso: noviembre-2007
Ubicación: Actualmente en Buenos Aires (el enemigo ancestral)
Mensajes: 23.324
Antigüedad: 16 años, 5 meses
Puntos: 2658
Respuesta: Problema con Triggers en MySQL

Código:
DELIMITER $$

CREATE TRIGGER trigger_cambios 
BEFORE UPDATE ON componentes 
FOR EACH ROW 

BEGIN 
    INSERT INTO cambios( componenteviejo, componentenuevo, usuario, fecha_cambio ) 
    VALUES (OLD.num_serie, NEW.num_serie, NEW.id_persona, NOW( ) );

END$$

DELIMITER ;
No está cerrado el trigger, falta el END

DELIMITER es para cambiar momentaneamente el termiandor de sentencia para poder enviar el conjunto completo del script en una sola carga.
__________________
¿A quién le enseñan sus aciertos?, si yo aprendo de mis errores constantemente...
"El problema es la interfase silla-teclado." (Gillermo Luque)
  #3 (permalink)  
Antiguo 02/09/2008, 12:30
 
Fecha de Ingreso: septiembre-2008
Mensajes: 3
Antigüedad: 15 años, 7 meses
Puntos: 0
Respuesta: Problema con Triggers en MySQL

Muchas Gracias gnzsoloyo a los 15 min de publicar mi solicitud de ayuda.. solucione mi problema :D!!!.. lo solucione quitando el BEGIN nose porque pero al quitarlo me funciono perfectamente... tavez sea porque tengo la vercion 6 de MySQL... talvez cambio la sintaxys en ese aspecto..

Gracias..
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 08:39.