Solved

automatic email alert

Posted on 2016-11-23
1
68 Views
Last Modified: 2016-11-24
hi experts,

i have two tables. in table1 i have two columns (store,email),in table2 i have two columns (store,logs). In table1 ,for one particular store we have only one email id associated. but in table2 with one particular store we will have multiple logs. What i need to do is i need to send an email to that email id with which the store is attached in table1 and in the body of that email i will have the names of the logs associated with that store in table2. I need to use plsql query for this. please help me with this issue. i have attached the screenshorts of demo tables.

thanks.
table2.PNG
table1.PNG
0
Comment
Question by:sam shah
1 Comment
 
LVL 74

Accepted Solution

by:
sdstuber earned 500 total points
ID: 41899087
Do you need to send the file names or the contents of those files?

If the contents, where are the files?
And, should the contents be written into the body of the email, or sent as attachments?


If you only need to send the file names, then something like this should work...

DECLARE
    v_connection   UTL_SMTP.connection;
BEGIN
    FOR e IN (SELECT e.store, e.email
                FROM store_emails e
               WHERE e.store IN (SELECT l.store
                                   FROM store_logs))
    LOOP
        v_connection := UTL_SMTP.open_connection('your.email.server.com');
        UTL_SMTP.helo(v_connection, 'your.domain.com');
        UTL_SMTP.mail(v_connection, 'your_return_address@your.domain.com');
        UTL_SMTP.rcpt(v_connection, e.email);
        UTL_SMTP.open_data(v_connection);

        UTL_SMTP.write_data(v_connection, 'From: Your Name' || UTL_TCP.crlf);
        UTL_SMTP.write_data(v_connection, 'To: ' || e.email || UTL_TCP.crlf);
        UTL_SMTP.write_data(v_connection, 'Subject: Store Logs' || UTL_TCP.crlf);
        UTL_SMTP.write_data(v_connection, UTL_TCP.crlf);

        -- This is easy and likely sufficient for short emails
        -- but, if your email body becomes large
        -- you may want to construct it as a clob before connecting to the email server
        -- then write the clob into the email body so you don't get timeouts
        FOR l IN (SELECT logs
                    FROM store_logs l
                   WHERE l.store = e.store)
        LOOP
            UTL_SMTP.write_data(v_connection, l.logs || UTL_TCP.crlf);
        END LOOP;

        UTL_SMTP.close_data(v_connection);
        UTL_SMTP.quit(v_connection);
    END LOOP;
EXCEPTION
    WHEN OTHERS
    THEN
        DBMS_OUTPUT.put_line(DBMS_UTILITY.format_error_stack);
END;

Open in new window

0

Featured Post

Free Tool: Subnet Calculator

The subnet calculator helps you design networks by taking an IP address and network mask and returning information such as network, broadcast address, and host range.

One of a set of tools we're offering as a way of saying thank you for being a part of the community.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

I remember the day when someone asked me to create a user for an application developement. The user should be able to create views and materialized views and, so, I used the following syntax: (CODE) This way, I guessed, I would ensure that use…
In this article we will learn how to fix  “Cannot install SQL Server 2014 Service Pack 2: Unable to install windows installer msi file” error ?
This video shows, step by step, how to configure Oracle Heterogeneous Services via the Generic Gateway Agent in order to make a connection from an Oracle session and access a remote SQL Server database table.
This video shows syntax for various backup options while discussing how the different basic backup types work.  It explains how to take full backups, incremental level 0 backups, incremental level 1 backups in both differential and cumulative mode a…

730 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question