Utilizamos cookies propias y de terceros. [Más información sobre las cookies].
Política de cookies
Proyecto AjpdSoft

· Inicio
· Buscar
· Contactar
· Cookies
· Descargas
· Foros
· Historia
· Nosotros
· Temas
· Top 10
· Trucos
· Tutoriales
· Wiki
Proyecto AjpdSoft: Foros

AjpdSoft :: Ver tema - Enviar un email de notificación cada vez que se dé un evento
Foros de discusión Buscar Perfil FAQ Iniciar sesión
Information Enviar un email de notificación cada vez que se dé un evento

Publicar nuevo tema Responder al tema
Foros de discusión » Oracle Database, motor de base de datos profesional   
Ver tema anterior :: Ver tema siguiente
AutorMensaje
varios
Magnífico usuario


Registrado: Oct 10, 2006
Mensajes: 2092

Asunto: Enviar un email de notificación cada vez que se dé un evento Responder citando

Tengo una base de datos Oracle 11g, no sé mucho de programación y me gustaría saber si hay algún método para que cuando se produzca una determinada circunstancia en un registro de una tabla de Oracle (por ejemplo si el importe introducido en la tabla "facturas" es superior a 10000) avise mediante el envío de un email.

¿esto es posible? ¿cómo?
MensajePublicado:
Mar Ago 25, 2009 11:08 am
Top of PageVer perfil de usuario
alonsojpd
Administrador/Moderador


Registrado: Sep 16, 2003
Mensajes: 2687

Asunto: Re: Enviar un email de notificación cada vez que se dé un ev Responder citando



Anuncios



varios escribió:
Tengo una base de datos Oracle 11g, no sé mucho de programación y me gustaría saber si hay algún método para que cuando se produzca una determinada circunstancia en un registro de una tabla de Oracle (por ejemplo si el importe introducido en la tabla "facturas" es superior a 10000) avise mediante el envío de un email.

¿esto es posible? ¿cómo?


Sí es posible, por un lado necesitarías conocer qué son los triggers (disparadores) en Oracle y cómo usarlos. En el siguiente artículo explicamos esto:

http://www.ajpdsoft.com/modules.php?name=News&file=article&sid=178

Por otro lado, tendrás que usar algún procedimiento como el siguiente para enviar el email desde Oracle, aunque no lo recomendamos. Para enviar el email desde Oracle usamos el paquete UTL_MAIL:

Código:

CREATE OR REPLACE PROCEDURE SEND_MAIL (
msg_to varchar2,
msg_subject varchar2,
msg_text varchar2 )
IS
c utl_smtp.connection;
rc integer;
msg_from varchar2(50) := 'Oracle9.2';
mailhost VARCHAR2(30) := '127.0.0.1'; -- local database host

BEGIN
c := utl_smtp.open_connection(mailhost, 25); -- SMTP on port 25
utl_smtp.helo(c, mailhost);
utl_smtp.mail(c, msg_from);
utl_smtp.rcpt(c, msg_to);

utl_smtp.data(c,'From: Oracle Database' || utl_tcp.crlf ||
'To: ' || msg_to || utl_tcp.crlf ||
'Subject: ' || msg_subject ||
utl_tcp.crlf || msg_text);
utl_smtp.quit(c);

EXCEPTION
WHEN UTL_SMTP.INVALID_OPERATION THEN
dbms_output.put_line(' Invalid Operation in Mail attempt
using UTL_SMTP.');
WHEN UTL_SMTP.TRANSIENT_ERROR THEN
dbms_output.put_line(' Temporary e-mail issue - try again');
WHEN UTL_SMTP.PERMANENT_ERROR THEN
dbms_output.put_line(' Permanent Error Encountered.');
END;
/


Nuestra recomendación es la siguiente:

1. Crea una tabla en Oracle que puedes llamar, por ejemplo, "eventos", esta tabla podría tener los siguientes campos: Codigo, Fecha y hora, Notificado, Tipo evento, Texto aviso. Esto es un ejemplo para que entiendas la mejor forma de hacer esto, obviamente deberás crear la tabla según tus necesidades.

2. Desde el trigger de Oracle, insertarás un registro en la tabla "eventos" cuando lo estimes pertinente (por ejemplo cuando el usuario inserta un registro en la tabla "facturas" con importe superior a 10.000 euros. En este caso el trigger insertará un registro en la tabla con los datos que consideres y el campo "Notificado" a "No".

3. Por otro lado deberás desarrollar una aplicación (a ser posible un servicio) con cualquier lenguaje de programación sencillo (Visual Basic .Net, Delphi) que consulte la tabla "evento" cada cierto tiempo y filtre sólo los eventos no notificados, si encuentra alguno, según el tipo de evento, enviará un email al usuario o usuarios asociados (que podrían estar en otra tabla de "usuarios"). Una vez que la aplicación envía el mail de notificación marcará el registro como "Notificado" para que no se vuelva a enviar el mail.

Este método es mucho más eficiente que enviar un mail desde Oracle, sobre todo porque tendrás un histórico de eventos notificados y no notificados y podrás personalizar todo lo que quieras la forma de envío, incluso con SMS (usando un módem GSM). Sobre todo porque la aplicación que desarrollarías desde fuera de Oracle será mucho más flexible que el propio Oracle.
MensajePublicado:
Vie Ago 12, 2011 7:56 pm
Top of PageVer perfil de usuario
Mostrar mensajes de anteriores:   
Todas las horas son GMT - 1 Horas
Publicar nuevo tema Responder al tema
Foros de discusión » Oracle Database, motor de base de datos profesional  

Cambiar a:  
Key
  Puede publicar nuevos temas en este foro
No puede responder a temas en este foro
No puede editar sus mensajes en este foro
No puede borrar sus mensajes en este foro
No puede votar en encuestas en este foro
Visita nuestro nuevo sitio web con programas y contenidos actualizados: Proyecto A