扫二维码与项目经理沟通
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流
分两步做,
创新互联公司主要从事成都网站制作、成都网站建设、外贸营销网站建设、网页设计、企业做网站、公司建网站等业务。立足成都服务古交,十余年网站建设经验,价格优惠、服务专业,欢迎来电咨询建站服务:18980820575
1.oracle 当表中数据发生变化insert或者update
这个需要触发器的,但是触发器的作用也无非是数据库层面的操作,这样最好触发添加一条记录到邮件通知表,这个表加个状态state=0
2.用程序轮训定时扫描这个邮件通知表,周期可以设置为30秒扫描一次,扫描到的记录,进行邮件发送以及这个表记录的状态修改为state=1
在 Oracle 的运维过程中,常常需要监控任务执行情况,这时候如果用 Java 或 Python 都可以自定义一个发邮件提醒的功能,但如果能调用 Oracle 自带的的一些包来实现邮件提醒,不仅调用方便,而且提醒的灵活度更高(可以插在存储过程的任意一个犄角旮旯里)。
这里有两篇文章,详细介绍了调用 Oracle 系统包实现邮件提醒功能的两种方法:
我在使用这两个包的时候,遇到了“ORA-24247: 网络访问被访问控制列表 (ACL) 拒绝”的报错。我先检查了用户权限,然后检查了邮件服务器的端口权限,都没问题,于是在网络上搜索答案,原来真的报错提示很明显,就是 ACL 权限问题,不是其他。
于是参照 ORA-24247: 网络访问被访问控制列表 (ACL) 拒绝 这篇文章中的方法重新设置,一调试,果然可以正常发邮件了。
一般不建议数据库服务器直接与外部连接。建议用第三方软件,比如easysqlmail之类的。第一,安全,第二,简单。自己集中精力把sql写好就可以了。望采纳。
1.
首先要启用数据库邮件存储过程。具体操作如下: 在“开始”菜单上,依次指向“所有程序”、Microsoft SQL Server 2005、“”,然后单击“SQL Server 外围应用配置器”。 单击...
2.
当启用数据库邮件存储过程成功以后。我们就要开始配置我们的数据库邮件配置文件了。具体操作如下: 使用对象资源管理器,连接到配置了...
3.
现在我们就可以开始测试一下邮件的发送了。
Oracle 提供了一个SendMail的套件: utl_smtp.
可以利用utl_smtp来在PL/SQL发送邮件。
utl_smtp相关函数以及用法如下所示。
declare
mailhost VARCHAR2(50) := 'XXX.XXX.com';
mail_conn utl_smtp.connection; --定义
begin
-- 开启 Mail Connection
mail_conn := utl_smtp.open_connection(mailhost);
-- 建立连接
utl_smtp.helo(mail_conn, mailhost);
-- 设定发件者
utl_smtp.mail(mail_conn, 'yun@xxx.com');
-- 设定收件者
utl_smtp.rcpt(mail_conn, 'feng@xxx.com');
-- 设定邮件内容
utl_smtp.data(mail_conn, 'Subject:Oracle Send Mail Test' || utl_tcp.CRLF ||
'To:feng@xxx.com' || utl_tcp.CRLF ||
'Cc:lei@xxx.com' || utl_tcp.CRLF ||
'Hello World!'
);
-- 关闭连接
utl_smtp.quit(mail_conn);
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流