仓酷云

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 898|回复: 7
打印 上一主题 下一主题

[学习教程] MYSQL网站制作之ORACLE 主动发邮件代码

[复制链接]
老尸 该用户已被删除
跳转到指定楼层
#
发表于 2015-1-16 22:13:09 | 只看该作者 回帖奖励 |正序浏览 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
DBaaS系统其实具有更大的市场机遇:像其他云服务一样,DBaaS意味着更短的销售周期,更少的启动费用,持续不断的收入,也意味着比之前更多的客户。<P>该程序剧本最次要的功效完成为经由过程oracle自带的历程包发送邮件来监控ETL的实行情形:
ORACLE_SID=orcl
ORACLE_BASE=/opt/oracle
ORACLE_HOME=/opt/oracle/product/10.2.0
exportORACLE_SIDORACLE_BASEORACLE_HOME
PWD_DIR=/home/oracle/shell
SQLPLUS=${ORACLE_HOME}/bin/sqlplus
CONFIG_INI=${PWD_DIR}/ini/config.ini
whilereadgameuser
do
echo${gameuser}
echo${SQLPLUS}
cd${PWD_DIR}
${SQLPLUS}${gameuser}<<!
@etl_monitor.sql;
/
exit;
!
done<${CONFIG_INI}
etl_monitor.sql剧本为:
DECLARE
p_txtVARCHAR2(4000);
p_txt_allVARCHAR2(4000);
BEGIN
FORrIN(SELECTjob_name,
run_cnt,
table_name,
column_name
FROMetl_monitor_config_tab)
LOOP
--CalltheEtlMonitorfunction
p_txt:=
etl_monitor(r.job_name,
r.run_cnt,
r.table_name,
r.column_name);
p_txt_all:=p_txt_allCHR(13)p_txt;
ENDLOOP;
--CalltheSendMailfunction
procsendemail(p_txt_all,
EtlMoniotr,
xxx@163.com,
xxxx@kingsoft.com,
mail.kingsoft.com,
25,
1,
xxxxxx,
xxxxxx,
,
bit7);
p_txt_all:=;
END;
createorreplacefunctionetl_monitor(job_namevarchar2,
run_cntint,
table_namevarchar2,
column_namevarchar2)
RETURNvarchar2IS
v_monitor_datedate;--Themonitoroftheprocsdate
v_job_namevarchar2(130);
v_log_idnumber;
v_result1char(1);--Thestatusoftheprocsresult1
v_result2char(1);--Thestatusoftheprocsresult2
v_status_cntint;
v_record_numint;--Thenumberofthejobrun
v_resultvarchar2(4000);
v_sqlvarchar2(1000);
begin
v_monitor_date:=trunc(sysdate);
v_job_name:=job_name;
v_result1:=0;
v_result2:=0;
v_sql:=selectcount(1)from;
ifrun_cnt=1then
selectlog_id
intov_log_id
fromuser_scheduler_job_run_details
wherejob_name=v_job_name
andtrunc(actual_start_date)=v_monitor_date;
else
selectmax(log_id)
intov_log_id
fromuser_scheduler_job_run_details
wherejob_name=v_job_name
andtrunc(actual_start_date)=v_monitor_date;
endif;
selectcount(*)
intov_status_cnt
fromuser_scheduler_job_run_details
wherelog_id=v_log_id
andstatus=SUCCEEDED;
ifv_status_cnt=0then
gotoerror1;
endif;
v_result1:=1;
v_sql:=v_sqltable_namewheretrunc(column_name
)=trunc(sysdate-1)andrownum=1;
executeimmediatev_sql
intov_record_num;
ifv_record_num>0then
v_result2:=1;
else
v_status_cnt:=0;
gotoerror1;
endif;
ifv_result1=1andv_result2=1then
v_result:=SYS_CONTEXT(USERENV,CURRENT_SCHEMA).
v_job_nameAtv_monitor_dateISSUCCEEDED;
endif;
<<error1>>
ifv_status_cnt=0then
selectOWNER.JOB_NAMEAtTRUNC(ACTUAL_START_DATE)
ISADDITIONAL_INFO
intov_result
fromuser_scheduler_job_run_details
wherelog_id=v_log_id;
endif;
returnv_result;
exception
whenothersthen
returnSYS_CONTEXT(USERENV,CURRENT_SCHEMA).v_job_nameAtv_monitor_dateISNOTEXECUTE;
end;12345下一页>全文浏览提醒:尝尝"←→"键,翻页更便利哦!MySQL数据库归MySQLAB公司所有,但是这个软件是开源的,有一个MySQL学习教程可以免费下载。稍俱常识的新入门者都可以轻松实现在一个常见硬件上安装和配置MySQL。
谁可相欹 该用户已被删除
7#
发表于 2015-3-21 01:27:44 | 只看该作者
在select语句中可以使用groupby子句将行划分成较小的组,然后,使用聚组函数返回每一个组的汇总信息,另外,可以使用having子句限制返回的结果集。
变相怪杰 该用户已被删除
6#
发表于 2015-3-14 06:48:44 | 只看该作者
还不是性能有问题!否则面向对象的数据库早就实现了!建议使用CLR的地方一般是和应用的复杂程度或操作系统环境有很高的耦合度的场景。如你想构建复杂的算法,并且用到了大量的指针和高级数据模型。
透明 该用户已被删除
5#
发表于 2015-3-7 01:45:57 | 只看该作者
入门没那么困难,精通没那么容易
再现理想 该用户已被删除
地板
发表于 2015-2-22 18:37:53 | 只看该作者
代替了原来VB式的错误判断。比Oracle高级不少。
小魔女 该用户已被删除
板凳
发表于 2015-2-7 17:05:17 | 只看该作者
SQLServer的异构移植功能个人感觉最好了。(如果对比过SQLServer的链接服务器和Oracle的透明网关的朋友会发现SQLServer的sp_addlinkedserver(openquery)异构数据库系列比Oracle真是强太多了。)
小妖女 该用户已被删除
沙发
发表于 2015-1-24 15:45:25 | 只看该作者
所以你总能得到相应的升级版本,来满足你的需求。
灵魂腐蚀 该用户已被删除
楼主
发表于 2015-1-19 05:08:36 | 只看该作者
对递归类的树遍历很有帮助。个人感觉这个真是太棒了!阅读清晰,非常有时代感。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|仓酷云 鄂ICP备14007578号-2

GMT+8, 2025-1-18 22:14

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表