shell脚本:数据库业务监控
admin
2023-06-10 03:22:21
0


#!/bin/bash

#先写一个简单的脚本,后续使用脚本调用存储过程

#by:亚信-张颜


export ORACLE_HOME=/opt/oracle/app/oracle_base/product/11.2.0/db_1

export PATH=$ORACLE_HOME/bin:$PATH


#DATE_STR保存了从数据库中返回的三个值:1小时之前的年月,12小时前的时间串,以及当前时间串

DATE_STR=(`sqlplus -s  用户名/密码 <

set heading off

set feedback off

set pagesize 0

set verify off

set echo off

select to_char(TRUNC(SYSDATE - 1 / 24, 'HH'), 'YYYYMM'),TO_CHAR(TRUNC(SYSDATE - 1 / 2, 'HH'), 'YYYYMMDDHH24MISS'),

       TO_CHAR(TRUNC(SYSDATE, 'HH'), 'YYYYMMDDHH24MISS')  from dual;

exit;

eof`)


echo "`date` 开始校验程控退订数据......"

echo "`date` 开始提取程控功能营业送开通表退订数据"


#通过监控营业送开通工单历史表,查询程控功能退订的数据,当前设定为12个小时运行1次

#

for REGION_ID in {891..897}

do

sqlplus -s  用户名/密码 <

set heading off

set feedback off

set pagesize 0

set verify off

set echo off

insert into zyan_jiankongchengkong

select bill_id, 'MBELL', create_date, sysdate

  from so.i_open_provision_h_${REGION_ID}_${DATE_STR[0]}

 where action_id = 5

   and OLD_PS_PARAM like '%MBELL=1%'

   and (PS_PARAM is null or PS_PARAM not like '%MBELL=1%')

   and create_date >= TO_DATE('${DATE_STR[1]}', 'YYYYMMDDHH24MISS')

   and create_date < TO_DATE('${DATE_STR[2]}', 'YYYYMMDDHH24MISS');

commit;

insert into zyan_jiankongchengkong

  select bill_id, 'CFNRCF', create_date, sysdate

    from so.i_open_provision_h_${REGION_ID}_${DATE_STR[0]}

   where action_id = 5

     and OLD_PS_PARAM like '%CFNRCF=1%'

     and (PS_PARAM is null or PS_PARAM not like '%CFNRCF=1%')

     and create_date >= TO_DATE('${DATE_STR[1]}', 'YYYYMMDDHH24MISS')

     and create_date < TO_DATE('${DATE_STR[2]}', 'YYYYMMDDHH24MISS');

commit;

exit;

eof

done



#校验程控功能订购在退订功能时是否存在订购关系,如果存在则表示是异常,需要进一步核查:

echo "`date` 开始校验程控退订记录营业侧订购关系:"


for REGION_ID in {891..897}

do

sqlplus -s  用户名/密码 <

set heading off

set feedback off

set pagesize 0

set verify off

set echo off

 delete from zyan_jiankongchengkong a

   where create_date <> (select max(create_date)

                           from zyan_jiankongchengkong b

                          where a.bill_id = b.bill_id

                            and a.func_name = b.func_name)

                            and a.done_date>TO_DATE('${DATE_STR[2]}', 'YYYYMMDDHH24MISS');

                            commit;

delete from zyan_jiankongchengkong a

 where not exists (select 1

          from so.ins_user_${REGION_ID}         b,

               so.ins_prod_${REGION_ID}         c,

               so.ins_off_ins_user_${REGION_ID} f

         where a.bill_id = b.bill_id

           and c.prod_id in (121030512001, 121030512002)

           and b.user_id = c.user_id

           and c.user_id = f.user_id

           and c.offer_inst_id = f.offer_inst_id

           and b.region_id=f.region_id

           and f.expire_date > sysdate

           and c.expire_date > sysdate

           and c.effective_date < a.create_date

           and c.create_date

           and exists (select 1 from so. ins_user_${REGION_ID} g where a.bill_id = g.bill_id)

   and a.func_name = 'MBELL'

   and a.done_date>TO_DATE('${DATE_STR[2]}', 'YYYYMMDDHH24MISS');

   commit;

 delete from zyan_jiankongchengkong a

 where not exists (select 1

          from so.ins_user_${REGION_ID}         b,

               so.ins_prod_${REGION_ID}         c,

               so.ins_off_ins_user_${REGION_ID} f

         where a.bill_id = b.bill_id

           and c.prod_id in (121030505101)

           and b.user_id = c.user_id

           and c.user_id = f.user_id

           and c.offer_inst_id = f.offer_inst_id

           and b.region_id=f.region_id

           and f.expire_date > sysdate

           and c.expire_date > sysdate

           and c.effective_date < a.create_date

           and c.create_date

           and exists (select 1 from so. ins_user_${REGION_ID} g where a.bill_id = g.bill_id)

   and a.func_name = 'CFNRCF'

   and a.done_date>TO_DATE('${DATE_STR[2]}', 'YYYYMMDDHH24MISS');

commit;

exit;

eof

done


echo "`date` 本次校验完成!"

echo ""


相关内容

热门资讯

伊朗总统:准备向世界保证不寻求... 据阿纳多卢通讯社报道,当地时间5月24日,伊朗总统佩泽希齐扬在接受伊朗伊斯兰共和国通讯社(IRNA)...
鲁比奥谈美伊核谈判:不可能在餐... 据凤凰卫视报道,正在印度访问的美国国务卿鲁比奥5月24日表示,美国与伊朗之间的协议草案已获多个中东地...
人形机器人开启集体上“户口” ... 近日,全国首个人形机器人全生命周期管理服务平台正式落地,搭配配套《人形机器人全生命周期管理规范》标准...
德国性侵案华人团伙主犯被判14... 2024年,德国和中国警方联合破获一起涉及在德中国公民的下药性侵案件,被逮捕的是43岁中国籍男子张大...
吉田茂的这句告诫,值得日本政府... 高市早苗出任首相后,日本修宪动向再度成为舆论焦点。自民党一方面以“安全保障形势发生剧变”为借口,谋求...
人形机器人,要有身份证了! ◎ 科技日报记者 华凌 22日, 全国首个人形机器人全生命周期管理服务平台在北京发布,《人形机器人全...
伊朗现在哭笑不得 感觉伊朗现在正哭笑不得。与美国的谈判在进行中,特朗普也在不断发帖“指导”中,但按照伊朗的说法,美国官...
最新研究:银河系多数岩质行星构... IT之家 5 月 24 日消息,我们对太阳系内的行星已有诸多认知,长期以来,我们都认为银河系其他区域...
灵动岛缩减35% 史上颜值巅峰... PChome 5月23日消息,随着iPhone 18 Pro和iPhone 18 Pro Max的贴...
双方互攻伤亡大,学校被袭引关切... 【环球时报驻俄罗斯特派记者 隋鑫 郑真】俄罗斯国防部24日表示,为回应乌克兰对俄方民用基础设施的恐怖...