all.sql 156 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999300030013002300330043005300630073008300930103011301230133014301530163017301830193020302130223023302430253026302730283029303030313032303330343035303630373038303930403041304230433044304530463047304830493050305130523053305430553056305730583059306030613062306330643065306630673068306930703071307230733074307530763077307830793080308130823083308430853086308730883089309030913092309330943095309630973098309931003101310231033104310531063107310831093110311131123113311431153116311731183119312031213122312331243125312631273128312931303131313231333134313531363137313831393140314131423143314431453146314731483149315031513152315331543155315631573158315931603161316231633164316531663167316831693170317131723173317431753176317731783179318031813182318331843185318631873188318931903191319231933194319531963197319831993200320132023203320432053206320732083209321032113212321332143215321632173218321932203221322232233224322532263227322832293230323132323233
  1. use lawe;
  2. -- (1)基础设施
  3. -- 建表语句
  4. DROP TABLE IF EXISTS `bi_itm_hardware_resources`;
  5. CREATE TABLE `bi_itm_hardware_resources` (
  6. `itm_hardware_resources_id` varchar(100) DEFAULT NULL COMMENT '设备ID',
  7. `itm_hardware_resources_type` varchar(100) DEFAULT NULL COMMENT '设备型号ID',
  8. `itm_hardware_resources_cntype` varchar(100) DEFAULT NULL COMMENT '设备型号归类',
  9. `itm_hardware_resources_areacode` varchar(100) DEFAULT NULL COMMENT '设备区域',
  10. `ITM_HARDWARE_RESOURCES_ASSNO` varchar(100) DEFAULT NULL COMMENT '国资码暂时用来存储设备所属应用名称',
  11. `ITM_HARDWARE_RESOURCES_CODE` varchar(200) DEFAULT NULL COMMENT '设备编码',
  12. `ITM_HARDWARE_RESOURCES_NAME` varchar(255) DEFAULT NULL COMMENT '设备名称',
  13. `ITM_HARDWARE_RESOURCES_IP` varchar(64) DEFAULT NULL COMMENT '设备IP',
  14. `ITM_HARDWARE_RESOURCES_STATUS` varchar(64) DEFAULT NULL COMMENT '使用状态:在用,停用',
  15. `itm_monitor_flag` varchar(10) DEFAULT NULL COMMENT '监控状态:监控,未监控',
  16. `create_time` datetime DEFAULT NULL COMMENT '设备创建时间',
  17. `NAME` varchar(512) DEFAULT NULL COMMENT '设备名称',
  18. `resclasscnname` varchar(255) DEFAULT NULL COMMENT '设备类型',
  19. `NET_NAME` varchar(64) DEFAULT NULL COMMENT '网系',
  20. `ROOM_JIFANG` varchar(64) DEFAULT NULL COMMENT '所属机房',
  21. `UID` varchar(100) DEFAULT NULL COMMENT 'UID',
  22. `pinpai` varchar(255) DEFAULT NULL COMMENT '设备品牌',
  23. `xinghao` varchar(255) DEFAULT NULL COMMENT '设备型号',
  24. `mac` varchar(255) DEFAULT NULL COMMENT 'mac地址',
  25. `guoziguishurenyuan` varchar(255) DEFAULT NULL COMMENT '国资归属人员',
  26. `guoziguishubumen` varchar(255) DEFAULT NULL COMMENT '国资归属部门',
  27. `yunweirenyuan` varchar(255) DEFAULT NULL COMMENT '运维人员',
  28. `servicename` varchar(255) DEFAULT NULL COMMENT '服务app名',
  29. `relatedappid` varchar(255) DEFAULT NULL COMMENT '关联appid',
  30. `mantancevendor` varchar(255) DEFAULT NULL COMMENT '运维厂商',
  31. `cloud` varchar(255) DEFAULT NULL COMMENT '云平台',
  32. KEY `bi_itm_hardware_resources_itm_hardware_resources_id_IDX` (`itm_hardware_resources_id`) USING BTREE
  33. ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
  34. truncate table bi_itm_hardware_resources;
  35. insert into bi_itm_hardware_resources
  36. SELECT
  37. IzGoY.itm_hardware_resources_id,
  38. IzGoY.itm_hardware_resources_type,
  39. case
  40. when IzGoY.itm_hardware_resources_type = '000100001' then '物理机'
  41. when IzGoY.itm_hardware_resources_type = '000100002' then '云主机'
  42. when IzGoY.itm_hardware_resources_type = '000100004' then '宿主机'
  43. when substr(IzGoY.itm_hardware_resources_type,1,4) = '0001' then '其他主机'
  44. when IzGoY.itm_hardware_resources_type = '000200001' then '交换机'
  45. when IzGoY.itm_hardware_resources_type = '000200002' then '路由器'
  46. when IzGoY.itm_hardware_resources_type = '000300001' then '存储设备'
  47. when substr(IzGoY.itm_hardware_resources_type,1,4) = '0004' then '安全设备'
  48. else '非资产设备' end as itm_hardware_resources_cntype,
  49. case when IzGoY.itm_hardware_resources_areacode is null then '无区域' else IzGoY.itm_hardware_resources_areacode end as itm_hardware_resources_areacode,
  50. IzGoY.ITM_HARDWARE_RESOURCES_ASSNO,
  51. IzGoY.ITM_HARDWARE_RESOURCES_CODE,
  52. IzGoY.ITM_HARDWARE_RESOURCES_NAME,
  53. IzGoY.ITM_HARDWARE_RESOURCES_IP,
  54. IzGoY.ITM_HARDWARE_RESOURCES_STATUS,
  55. case when IzGoY.itm_monitor_flag = '1' then '监控' else '未监控' end as itm_monitor_flag,
  56. case when IzGoY.create_time is null then IzGoY.update_time else IzGoY.create_time end as create_time,
  57. XVuSA. NAME,
  58. -- dHSPj.resclasscnname,
  59. dHSPj.ITM_HARDWARE_RESOURCES_TYPE_NAME as resclasscnname,
  60. AIiKi.ITM_APPCATAGORY_NAME as NET_NAME,
  61. case when thd.ITM_HARDWARE_RESOURCES_NAME is null then '无机房' else thd.ITM_HARDWARE_RESOURCES_NAME end as ROOM_JIFANG,
  62. Qfqdl.UID,
  63. Qfqdl.pinpai,
  64. Qfqdl.xinghao,
  65. Qfqdl.mac,
  66. Qfqdl.guoziguishurenyuan,
  67. Qfqdl.guoziguishubumen,
  68. case when IzGoY.itm_hardware_resources_type = '000100002' then Qfqdl.business_director else Qfqdl.yunweirenyuan end as yunweirenyuan,
  69. Qfqdl.servicename,
  70. Qfqdl.relatedappid,
  71. case when IzGoY.itm_hardware_resources_type = '000100002' then Qfqdl.contractor else Qfqdl.mantancevendor end as mantancevendor,
  72. IzGoY.cloud
  73. FROM
  74. itm_hardware_resources IzGoY
  75. LEFT JOIN
  76. (SELECT
  77. ITM_HARDWARE_RESOURCES_ID AS UID,
  78. max((CASE WHEN (ITM_HARDWARE_RESOURCES_PROCODE = 'brand_name') THEN ITM_HARDWARE_RESOURCES_VALUE ELSE '' END)) AS pinpai,
  79. max((CASE WHEN (ITM_HARDWARE_RESOURCES_PROCODE = 'model') THEN ITM_HARDWARE_RESOURCES_VALUE ELSE '' END)) AS xinghao,
  80. max((CASE WHEN (ITM_HARDWARE_RESOURCES_PROCODE = 'macaddress') THEN ITM_HARDWARE_RESOURCES_VALUE ELSE '' END)) AS mac,
  81. max((CASE WHEN (ITM_HARDWARE_RESOURCES_PROCODE = 'manager') THEN ITM_HARDWARE_RESOURCES_VALUE ELSE '' END)) AS guoziguishurenyuan,
  82. max((CASE WHEN (ITM_HARDWARE_RESOURCES_PROCODE = 'department') THEN ITM_HARDWARE_RESOURCES_VALUE ELSE '' END)) AS guoziguishubumen,
  83. max((CASE WHEN (ITM_HARDWARE_RESOURCES_PROCODE = 'mantance_duty') THEN ITM_HARDWARE_RESOURCES_VALUE ELSE '' END)) AS yunweirenyuan,
  84. max((CASE WHEN (ITM_HARDWARE_RESOURCES_PROCODE = 'service_name') THEN ITM_HARDWARE_RESOURCES_VALUE ELSE '' END)) AS servicename,
  85. max((CASE WHEN (ITM_HARDWARE_RESOURCES_PROCODE = 'related_app_id') THEN ITM_HARDWARE_RESOURCES_VALUE ELSE '' END)) AS relatedappid,
  86. max((CASE WHEN (ITM_HARDWARE_RESOURCES_PROCODE = 'mantance_vendor') THEN ITM_HARDWARE_RESOURCES_VALUE ELSE '' END)) AS mantancevendor,
  87. max((CASE WHEN (ITM_HARDWARE_RESOURCES_PROCODE = 'business_director') THEN ITM_HARDWARE_RESOURCES_VALUE ELSE '' END)) AS business_director,
  88. max((CASE WHEN (ITM_HARDWARE_RESOURCES_PROCODE = 'contractor') THEN ITM_HARDWARE_RESOURCES_VALUE ELSE '' END)) AS contractor
  89. FROM
  90. itm_hardware_resources_value
  91. GROUP BY
  92. ITM_HARDWARE_RESOURCES_ID
  93. ) Qfqdl ON IzGoY.ITM_HARDWARE_RESOURCES_ID = Qfqdl.UID
  94. LEFT JOIN pub_organ XVuSA ON IzGoY.ORGAN_ID = XVuSA. CODE
  95. LEFT JOIN itm_appcatagory AIiKi ON IzGoY.ITM_HARDWARE_RESOURCES_NETCODE = AIiKi.ITM_APPCATAGORY_CODE
  96. -- LEFT JOIN (select distinct case when substr(resclassenname,1,2) = 'P_' then substr(resclassenname,3) else resclassenname end as resclassenname,resclasscnname from m_resclass) dHSPj ON IzGoY.ne_type = dHSPj.resclassenname
  97. left join (select ITM_HARDWARE_RESOURCES_TYPE,ITM_HARDWARE_RESOURCES_TYPE_NAME from itm_hardware_resources_type) dHSPj on IzGoY.ITM_HARDWARE_RESOURCES_TYPE = dHSPj.ITM_HARDWARE_RESOURCES_TYPE
  98. left join itm_hardware_resources thd
  99. on IzGoY.ITM_HARDWARE_RESOURCES_ROOMCODE = thd.itm_hardware_resources_id where IzGoY.ITM_HARDWARE_RESOURCES_PTYPE IN ('0001','0002','000300001','0004')
  100. AND IzGoY.ITM_HARDWARE_RESOURCES_STATUS != '报废'
  101. and IzGoY.stateflag='0';
  102. -- (2)基础设施告警、基础设施故障告警、网络中断趋势、应用系统告警趋势、应用系统故障趋势
  103. -- 建表语句
  104. DROP TABLE IF EXISTS `bi_alm_group_by_time`;
  105. CREATE TABLE `bi_alm_group_by_time` (
  106. `dtype` varchar(5) NOT NULL DEFAULT '' COMMENT '日期格式',
  107. `thedvalue` varchar(17) DEFAULT NULL COMMENT '告警时间',
  108. `alarm_object_ip` varchar(300) DEFAULT NULL COMMENT '告警设备IP',
  109. `alarm_object_type` varchar(50) NOT NULL DEFAULT '' COMMENT '设备类型',
  110. `ITM_HARDWARE_RESOURCES_AREACODE` varchar(64) DEFAULT NULL COMMENT '告警设备区域',
  111. `ITM_HARDWARE_RESOURCES_ASSNO` varchar(100) DEFAULT NULL COMMENT '国资编码',
  112. `ITM_HARDWARE_RESOURCES_CODE` longtext COMMENT '设备编码',
  113. `ITM_HARDWARE_RESOURCES_NAME` varchar(512) DEFAULT NULL COMMENT '设备名称',
  114. `ITM_HARDWARE_RESOURCES_IP` varchar(300) DEFAULT NULL COMMENT '设备IP',
  115. `pinpai` varchar(255) DEFAULT NULL COMMENT '设备品牌',
  116. `xinghao` varchar(255) DEFAULT NULL COMMENT '设备型号',
  117. `ITM_HARDWARE_RESOURCES_NETNAME` varchar(255) DEFAULT NULL COMMENT '网系名称',
  118. `ITM_HARDWARE_RESOURCES_STATUS` varchar(64) DEFAULT NULL COMMENT '设备状态',
  119. `severity_type` varchar(2) NOT NULL DEFAULT '' COMMENT '告警等级',
  120. `title` varchar(256) DEFAULT NULL COMMENT '告警标题',
  121. `alarm_text` mediumtext COMMENT '告警内容',
  122. `guoziguishubumen` varchar(255) DEFAULT NULL COMMENT '国资归属部门',
  123. `yunweirenyuan` varchar(255) DEFAULT NULL COMMENT '运维人员',
  124. `alarm_count` double DEFAULT NULL COMMENT '告警次数',
  125. `alarm_time` decimal(58,4) DEFAULT NULL COMMENT '告警时长(h)',
  126. `alarm_zy_num` decimal(42,0) DEFAULT NULL COMMENT '故障次数',
  127. `total_zy_num` decimal(29,8) DEFAULT NULL COMMENT '总资产数(取平均)',
  128. `process_type_name` varchar(64) DEFAULT NULL COMMENT '故障类型',
  129. `app_id` varchar(64) DEFAULT NULL COMMENT '应用ID',
  130. `cloud` varchar(255) DEFAULT NULL COMMENT '云平台'
  131. ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
  132. -- 涉及视图
  133. create or replace view `v_bi_alm_all_alarm` as
  134. select
  135. `t_alm_active_alarm`.`alarm_object_ip` as `alarm_object_ip`,
  136. `t_alm_active_alarm`.`alarm_object_id` as `alarm_object_id`,
  137. `t_alm_active_alarm`.`alarm_object_type` as `alarm_object_codetype`,
  138. (case
  139. when (`t_alm_active_alarm`.`alarm_object_type` = '000100001') then '物理机'
  140. when (`t_alm_active_alarm`.`alarm_object_type` = '000100002') then '云主机'
  141. when (`t_alm_active_alarm`.`alarm_object_type` = '000100004') then '宿主机'
  142. when (substr(`t_alm_active_alarm`.`alarm_object_type`, 1, 4) = '0001') then '其他主机'
  143. when (`t_alm_active_alarm`.`alarm_object_type` = '000200001') then '交换机'
  144. when (`t_alm_active_alarm`.`alarm_object_type` = '000200002') then '路由器'
  145. when (`t_alm_active_alarm`.`alarm_object_type` = '000300001') then '存储设备'
  146. when (substr(`t_alm_active_alarm`.`alarm_object_type`, 1, 4) = '0004') then '安全设备'
  147. when (substr(`t_alm_active_alarm`.`alarm_object_type`, 1, 4) = '0014') then '网络'
  148. when ((`t_alm_active_alarm`.`alarm_object_type` like '%0012%')
  149. or (`t_alm_active_alarm`.`alarm_object_type` like '%app%')) then '应用'
  150. else '其它未知类型'
  151. end) as `alarm_object_type`,
  152. `t_alm_active_alarm`.`alarm_object_name` as `alarm_object_name`,
  153. (`t_alm_active_alarm`.`alarm_count` + 0) as `alarm_count`,
  154. `t_alm_active_alarm`.`severity_id` as `severity_id`,
  155. `t_alm_active_alarm`.`occur_time` as `occur_time`,
  156. (case
  157. when isnull(`t_alm_active_alarm`.`update_time`) then `t_alm_active_alarm`.`insert_time`
  158. else `t_alm_active_alarm`.`update_time`
  159. end) as `end_time`,
  160. `t_alm_active_alarm`.`title` as `title`,
  161. `t_alm_active_alarm`.`alarm_text` as `alarm_text`,
  162. `t_alm_active_alarm`.`clr_status` as `clr_status`,
  163. 1 as `is_active_alarm`
  164. from
  165. `t_alm_active_alarm`
  166. union all
  167. select
  168. `t_alm_history_alarm`.`alarm_object_ip` as `alarm_object_ip`,
  169. `t_alm_history_alarm`.`alarm_object_id` as `alarm_object_id`,
  170. `t_alm_history_alarm`.`alarm_object_type` as `alarm_object_codetype`,
  171. (case
  172. when (`t_alm_history_alarm`.`alarm_object_type` = '000100001') then '物理机'
  173. when (`t_alm_history_alarm`.`alarm_object_type` = '000100002') then '云主机'
  174. when (`t_alm_history_alarm`.`alarm_object_type` = '000100004') then '宿主机'
  175. when (substr(`t_alm_history_alarm`.`alarm_object_type`, 1, 4) = '0001') then '其他主机'
  176. when (`t_alm_history_alarm`.`alarm_object_type` = '000200001') then '交换机'
  177. when (`t_alm_history_alarm`.`alarm_object_type` = '000200002') then '路由器'
  178. when (`t_alm_history_alarm`.`alarm_object_type` = '000300001') then '存储设备'
  179. when (substr(`t_alm_history_alarm`.`alarm_object_type`, 1, 4) = '0004') then '安全设备'
  180. when (substr(`t_alm_history_alarm`.`alarm_object_type`, 1, 4) = '0014') then '网络'
  181. when ((`t_alm_history_alarm`.`alarm_object_type` LIKE '%0012%')
  182. or (`t_alm_history_alarm`.`alarm_object_type` like '%app%')) then '应用'
  183. else '其它未知类型'
  184. end) as `alarm_object_type`,
  185. `t_alm_history_alarm`.`alarm_object_name` as `alarm_object_name`,
  186. (`t_alm_history_alarm`.`alarm_count` + 0) as `alarm_count`,
  187. `t_alm_history_alarm`.`severity_id` as `severity_id`,
  188. `t_alm_history_alarm`.`occur_time` as `occur_time`,
  189. (case
  190. when isnull(`t_alm_history_alarm`.`clear_time`) then `t_alm_history_alarm`.`insert_time`
  191. else `t_alm_history_alarm`.`clear_time`
  192. end) as `end_time`,
  193. `t_alm_history_alarm`.`title` as `title`,
  194. `t_alm_history_alarm`.`alarm_text` as `alarm_text`,
  195. `t_alm_history_alarm`.`clr_status` as `clr_status`,
  196. 0 as `is_active_alarm`
  197. from
  198. `t_alm_history_alarm`;
  199. truncate table bi_alm_group_by_time;
  200. insert into bi_alm_group_by_time
  201. select
  202. 'HOUR' AS dtype,
  203. DATE_FORMAT(occur_time,'%Y%m%d%H') as thedvalue,
  204. alarm_object_ip,alarm_object_type,ITM_HARDWARE_RESOURCES_AREACODE,ITM_HARDWARE_RESOURCES_ASSNO,ITM_HARDWARE_RESOURCES_CODE,
  205. ITM_HARDWARE_RESOURCES_NAME,ITM_HARDWARE_RESOURCES_IP,pinpai,xinghao,ITM_HARDWARE_RESOURCES_NETNAME,ITM_HARDWARE_RESOURCES_STATUS,severity_type,title,alarm_text,guoziguishubumen,yunweirenyuan,
  206. sum(alarm_count) as alarm_count,
  207. sum(alarm_time) as alarm_time,count(1) as alarm_zy_num,
  208. (select count(1) from bi_itm_hardware_resources where itm_hardware_resources_cntype != '非资产设备') as total_zy_num,
  209. process_type_name, app_id,m.cloud
  210. from (
  211. select
  212. a.occur_time,
  213. a.alarm_object_id,
  214. a.alarm_object_ip,
  215. a.alarm_object_type,
  216. b.ITM_HARDWARE_RESOURCES_AREACODE,
  217. b.ITM_HARDWARE_RESOURCES_ASSNO,
  218. b.ITM_HARDWARE_RESOURCES_CODE,
  219. b.ITM_HARDWARE_RESOURCES_NAME,
  220. b.ITM_HARDWARE_RESOURCES_IP,
  221. b.pinpai,
  222. b.xinghao,b.NET_NAME as ITM_HARDWARE_RESOURCES_NETNAME,b.ITM_HARDWARE_RESOURCES_STATUS,
  223. case a.severity_id when 1 then '致命' when 2 then '严重' when 3 then '一般' else '未知' end as severity_type,
  224. a.title,
  225. a.alarm_text,
  226. b.guoziguishubumen,
  227. b.yunweirenyuan,
  228. a.is_active_alarm,
  229. a.alarm_count,
  230. timestampdiff(MINUTE,a.occur_time,a.end_time)*1.0/60 as alarm_time,
  231. wf.process_type_name,wrr.app_id,b.cloud
  232. from (select * from v_bi_alm_all_alarm where alarm_object_type not in ('网络','应用')) a
  233. left join bi_itm_hardware_resources b on a.alarm_object_id = b.itm_hardware_resources_id
  234. LEFT JOIN icm_bpm.t_work_resource_real wrr on wrr.object_id = a.alarm_object_id
  235. left join icm_bpm.t_work_flow wf on wf.id=wrr.work_id) m
  236. group by
  237. DATE_FORMAT(occur_time,'%Y%m%d%H'),
  238. alarm_object_ip,alarm_object_type,ITM_HARDWARE_RESOURCES_AREACODE,ITM_HARDWARE_RESOURCES_ASSNO,ITM_HARDWARE_RESOURCES_CODE,
  239. ITM_HARDWARE_RESOURCES_NAME,ITM_HARDWARE_RESOURCES_IP,pinpai,xinghao,ITM_HARDWARE_RESOURCES_NETNAME,ITM_HARDWARE_RESOURCES_STATUS,severity_type,title,alarm_text,guoziguishubumen,yunweirenyuan,process_type_name,app_id,m.cloud;
  240. insert into bi_alm_group_by_time
  241. select
  242. 'DAY' AS dtype,
  243. substr(thedvalue,1,8) as thedvalue,
  244. alarm_object_ip,alarm_object_type,ITM_HARDWARE_RESOURCES_AREACODE,ITM_HARDWARE_RESOURCES_ASSNO,ITM_HARDWARE_RESOURCES_CODE,
  245. ITM_HARDWARE_RESOURCES_NAME,ITM_HARDWARE_RESOURCES_IP,pinpai,xinghao,ITM_HARDWARE_RESOURCES_NETNAME,ITM_HARDWARE_RESOURCES_STATUS,severity_type,title,alarm_text,guoziguishubumen,yunweirenyuan,
  246. sum(alarm_count) as alarm_count,sum(alarm_time) as alarm_time,sum(alarm_zy_num) as alarm_zy_num,max(total_zy_num) as total_zy_num, process_type_name, app_id, cloud
  247. from bi_alm_group_by_time where dtype = 'HOUR' and alarm_object_type not in ('网络','应用')
  248. group by
  249. substr(thedvalue,1,8),
  250. alarm_object_ip,alarm_object_type,ITM_HARDWARE_RESOURCES_AREACODE,ITM_HARDWARE_RESOURCES_ASSNO,ITM_HARDWARE_RESOURCES_CODE,
  251. ITM_HARDWARE_RESOURCES_NAME,ITM_HARDWARE_RESOURCES_IP,pinpai,xinghao,ITM_HARDWARE_RESOURCES_NETNAME,ITM_HARDWARE_RESOURCES_STATUS,severity_type,title,alarm_text,guoziguishubumen,yunweirenyuan,process_type_name,app_id,cloud;
  252. insert into bi_alm_group_by_time
  253. select
  254. 'MONTH' AS dtype,
  255. substr(thedvalue,1,6) as thedvalue,
  256. alarm_object_ip,alarm_object_type,ITM_HARDWARE_RESOURCES_AREACODE,ITM_HARDWARE_RESOURCES_ASSNO,ITM_HARDWARE_RESOURCES_CODE,
  257. ITM_HARDWARE_RESOURCES_NAME,ITM_HARDWARE_RESOURCES_IP,pinpai,xinghao,ITM_HARDWARE_RESOURCES_NETNAME,ITM_HARDWARE_RESOURCES_STATUS,severity_type,title,alarm_text,guoziguishubumen,yunweirenyuan,
  258. sum(alarm_count) as alarm_count,sum(alarm_time) as alarm_time,sum(alarm_zy_num) as alarm_zy_num,max(total_zy_num) as total_zy_num,process_type_name, app_id,cloud
  259. from bi_alm_group_by_time where dtype = 'DAY' and alarm_object_type not in ('网络','应用')
  260. group by
  261. substr(thedvalue,1,6),
  262. alarm_object_ip,alarm_object_type,ITM_HARDWARE_RESOURCES_AREACODE,ITM_HARDWARE_RESOURCES_ASSNO,ITM_HARDWARE_RESOURCES_CODE,
  263. ITM_HARDWARE_RESOURCES_NAME,ITM_HARDWARE_RESOURCES_IP,pinpai,xinghao,ITM_HARDWARE_RESOURCES_NETNAME,ITM_HARDWARE_RESOURCES_STATUS,severity_type,title,alarm_text,guoziguishubumen,yunweirenyuan,process_type_name,app_id,cloud;
  264. insert into bi_alm_group_by_time
  265. select
  266. 'YEAR' AS dtype,
  267. substr(thedvalue,1,4) as thedvalue,
  268. alarm_object_ip,alarm_object_type,ITM_HARDWARE_RESOURCES_AREACODE,ITM_HARDWARE_RESOURCES_ASSNO,ITM_HARDWARE_RESOURCES_CODE,
  269. ITM_HARDWARE_RESOURCES_NAME,ITM_HARDWARE_RESOURCES_IP,pinpai,xinghao,ITM_HARDWARE_RESOURCES_NETNAME,ITM_HARDWARE_RESOURCES_STATUS,severity_type,title,alarm_text,guoziguishubumen,yunweirenyuan,
  270. sum(alarm_count) as alarm_count,sum(alarm_time) as alarm_time,sum(alarm_zy_num) as alarm_zy_num,max(total_zy_num) as total_zy_num,process_type_name,app_id,cloud
  271. from bi_alm_group_by_time
  272. where dtype = 'MONTH' and alarm_object_type not in ('网络','应用')
  273. group by
  274. substr(thedvalue,1,4),
  275. alarm_object_ip,alarm_object_type,ITM_HARDWARE_RESOURCES_AREACODE,ITM_HARDWARE_RESOURCES_ASSNO,ITM_HARDWARE_RESOURCES_CODE,
  276. ITM_HARDWARE_RESOURCES_NAME,ITM_HARDWARE_RESOURCES_IP,pinpai,xinghao,ITM_HARDWARE_RESOURCES_NETNAME,ITM_HARDWARE_RESOURCES_STATUS,severity_type,title,alarm_text,guoziguishubumen,yunweirenyuan,process_type_name,app_id,cloud;
  277. insert into bi_alm_group_by_time (dtype,thedvalue,itm_hardware_resources_name,itm_hardware_resources_ip,itm_hardware_resources_areacode,
  278. pinpai,itm_hardware_resources_status,severity_type,title,alarm_text,guoziguishubumen,yunweirenyuan,xinghao,alarm_object_type,alarm_count,alarm_time,alarm_zy_num,total_zy_num,process_type_name,app_id
  279. )
  280. select
  281. 'HOUR' AS dtype,
  282. DATE_FORMAT(occur_time,'%Y%m%d%H') as thedvalue,
  283. m.itm_app_name as itm_hardware_resources_name,
  284. m.itm_app_systemurl as itm_hardware_resources_ip,
  285. m.net_name as itm_hardware_resources_areacode,
  286. m.priority as pinpai,
  287. m.stateflag as itm_hardware_resources_status,
  288. m.severity_type as severity_type,
  289. m.title as title,
  290. m.alarm_text as alarm_text,
  291. m.mantancevendor as guoziguishubumen,
  292. m.yunweirenyuan as yunweirenyuan,
  293. m.app_type_name as xinghao,
  294. '应用' as alarm_object_type,
  295. sum(alarm_count) as alarm_count,
  296. sum(alarm_time) as alarm_time,count(1) as alarm_zy_num,
  297. (select count(1) from itm_app) as total_zy_num,process_type_name,app_id
  298. from (
  299. select
  300. a.occur_time,
  301. a.alarm_object_id,
  302. case a.severity_id when 1 then '致命' when 2 then '严重' when 3 then '一般' else '未知' end as severity_type,
  303. a.title,
  304. a.alarm_text,
  305. a.is_active_alarm,
  306. a.alarm_count,
  307. timestampdiff(MINUTE,a.occur_time,a.end_time)*1.0/60 as alarm_time,
  308. b.itm_app_name as itm_app_name,
  309. b.itm_app_systemurl as itm_app_systemurl,
  310. case b.stateflag when 0 then '已应用' else '未应用' end as stateflag,
  311. case b.PRIORITY WHEN 'low' then '一般应用' when 'important' then '重要应用' when 'high' then '核心应用' else '未知' end as PRIORITY,
  312. d.name as app_type_name,
  313. e.name as net_name,
  314. '' as mantancevendor,
  315. b.mantance_duty as yunweirenyuan,
  316. wf.process_type_name,wrr.app_id
  317. from (select * from v_bi_alm_all_alarm where alarm_object_type ='应用') a
  318. left join itm_app b
  319. on a.alarm_object_id = b.ITM_APP_ID
  320. LEFT JOIN icm_bpm.t_work_resource_real wrr on wrr.object_id = a.alarm_object_id
  321. left join icm_bpm.t_work_flow wf on wf.id=wrr.work_id
  322. LEFT JOIN m_com_dict d on b.app_type=d.value
  323. LEFT JOIN m_com_dict e on e.value = b.ITM_NETGROUP_ID
  324. WHERE d.dict_index='app_type' and e.dict_index='itm_resources_netcode'
  325. ) m
  326. group by
  327. DATE_FORMAT(occur_time,'%Y%m%d%H'),
  328. pinpai,m.itm_app_name,m.itm_app_systemurl,m.net_name,m.priority,m.stateflag,m.severity_type,m.title,m.alarm_text,m.mantancevendor,m.yunweirenyuan,m.app_type_name,process_type_name,app_id;
  329. insert into bi_alm_group_by_time
  330. select
  331. 'DAY' AS dtype,
  332. substr(thedvalue,1,8) as thedvalue,
  333. alarm_object_ip,alarm_object_type,ITM_HARDWARE_RESOURCES_AREACODE,ITM_HARDWARE_RESOURCES_ASSNO,ITM_HARDWARE_RESOURCES_CODE,
  334. ITM_HARDWARE_RESOURCES_NAME,ITM_HARDWARE_RESOURCES_IP,pinpai,xinghao,ITM_HARDWARE_RESOURCES_NETNAME,ITM_HARDWARE_RESOURCES_STATUS,severity_type,title,alarm_text,guoziguishubumen,yunweirenyuan,
  335. sum(alarm_count) as alarm_count,sum(alarm_time) as alarm_time,sum(alarm_zy_num) as alarm_zy_num,max(total_zy_num) as total_zy_num, process_type_name, app_id,cloud
  336. from bi_alm_group_by_time where dtype = 'HOUR' and alarm_object_type = '应用'
  337. group by
  338. substr(thedvalue,1,8),
  339. alarm_object_ip,alarm_object_type,ITM_HARDWARE_RESOURCES_AREACODE,ITM_HARDWARE_RESOURCES_ASSNO,ITM_HARDWARE_RESOURCES_CODE,
  340. ITM_HARDWARE_RESOURCES_NAME,ITM_HARDWARE_RESOURCES_IP,pinpai,xinghao,ITM_HARDWARE_RESOURCES_NETNAME,ITM_HARDWARE_RESOURCES_STATUS,severity_type,title,alarm_text,guoziguishubumen,yunweirenyuan,process_type_name,app_id,cloud;
  341. insert into bi_alm_group_by_time
  342. select
  343. 'MONTH' AS dtype,
  344. substr(thedvalue,1,6) as thedvalue,
  345. alarm_object_ip,alarm_object_type,ITM_HARDWARE_RESOURCES_AREACODE,ITM_HARDWARE_RESOURCES_ASSNO,ITM_HARDWARE_RESOURCES_CODE,
  346. ITM_HARDWARE_RESOURCES_NAME,ITM_HARDWARE_RESOURCES_IP,pinpai,xinghao,ITM_HARDWARE_RESOURCES_NETNAME,ITM_HARDWARE_RESOURCES_STATUS,severity_type,title,alarm_text,guoziguishubumen,yunweirenyuan,
  347. sum(alarm_count) as alarm_count,sum(alarm_time) as alarm_time,sum(alarm_zy_num) as alarm_zy_num,max(total_zy_num) as total_zy_num, process_type_name, app_id,cloud
  348. from bi_alm_group_by_time where dtype = 'DAY' and alarm_object_type = '应用'
  349. group by
  350. substr(thedvalue,1,6),
  351. alarm_object_ip,alarm_object_type,ITM_HARDWARE_RESOURCES_AREACODE,ITM_HARDWARE_RESOURCES_ASSNO,ITM_HARDWARE_RESOURCES_CODE,
  352. ITM_HARDWARE_RESOURCES_NAME,ITM_HARDWARE_RESOURCES_IP,pinpai,xinghao,ITM_HARDWARE_RESOURCES_NETNAME,ITM_HARDWARE_RESOURCES_STATUS,severity_type,title,alarm_text,guoziguishubumen,yunweirenyuan,process_type_name, app_id,cloud;
  353. insert into bi_alm_group_by_time
  354. select
  355. 'YEAR' AS dtype,
  356. substr(thedvalue,1,4) as thedvalue,
  357. alarm_object_ip,alarm_object_type,ITM_HARDWARE_RESOURCES_AREACODE,ITM_HARDWARE_RESOURCES_ASSNO,ITM_HARDWARE_RESOURCES_CODE,
  358. ITM_HARDWARE_RESOURCES_NAME,ITM_HARDWARE_RESOURCES_IP,pinpai,xinghao,ITM_HARDWARE_RESOURCES_NETNAME,ITM_HARDWARE_RESOURCES_STATUS,severity_type,title,alarm_text,guoziguishubumen,yunweirenyuan,
  359. sum(alarm_count) as alarm_count,sum(alarm_time) as alarm_time,sum(alarm_zy_num) as alarm_zy_num,max(total_zy_num) as total_zy_num,process_type_name, app_id,cloud
  360. from bi_alm_group_by_time
  361. where dtype = 'MONTH' and alarm_object_type = '应用'
  362. group by
  363. substr(thedvalue,1,4),
  364. alarm_object_ip,alarm_object_type,ITM_HARDWARE_RESOURCES_AREACODE,ITM_HARDWARE_RESOURCES_ASSNO,ITM_HARDWARE_RESOURCES_CODE,
  365. ITM_HARDWARE_RESOURCES_NAME,ITM_HARDWARE_RESOURCES_IP,pinpai,xinghao,ITM_HARDWARE_RESOURCES_NETNAME,ITM_HARDWARE_RESOURCES_STATUS,severity_type,title,alarm_text,guoziguishubumen,yunweirenyuan,process_type_name, app_id,cloud;
  366. DROP TABLE IF EXISTS `bi_work_flow_group_row`;
  367. CREATE TABLE `bi_work_flow_group_row` (
  368. `dtype` varchar(5) CHARACTER SET utf8mb3 NOT NULL DEFAULT '',
  369. `thedvalue` varchar(15) CHARACTER SET utf8mb3 DEFAULT NULL,
  370. `process_type_name` varchar(255) DEFAULT NULL,
  371. `app_id` varchar(64) DEFAULT NULL,
  372. `app_name` varchar(64) DEFAULT NULL,
  373. `serve_area` varchar(32) DEFAULT NULL,
  374. `serve_department` varchar(32) DEFAULT NULL,
  375. `serve_firm` varchar(32) DEFAULT NULL,
  376. `agg` varchar(10) DEFAULT NULL,
  377. `unit` varchar(20) DEFAULT NULL,
  378. `kind` varchar(40) NOT NULL DEFAULT '',
  379. `value` double DEFAULT NULL
  380. ) ENGINE = InnoDB DEFAULT CHARSET = utf8;
  381. truncate table bi_work_flow_group_row;
  382. insert into bi_work_flow_group_row
  383. select m.dtype, m.thedvalue,m.process_type_name,m.app_id,ia.ITM_APP_NAME,m.serve_area,m.serve_department,m.serve_firm, 'SUM', '件', 'total_works' as 'kind', total_works as 'value'
  384. from bi_work_flow_group_by_time m
  385. left join itm_app ia on ia.ITM_APP_ID=m.app_id
  386. union all
  387. select m.dtype, m.thedvalue,m.process_type_name,m.app_id,ia.ITM_APP_NAME,m.serve_area,m.serve_department,m.serve_firm, 'SUM', '件', 'total_works_end' as 'kind', total_works_end as 'value'
  388. from bi_work_flow_group_by_time m
  389. left join itm_app ia on ia.ITM_APP_ID=m.app_id
  390. union all
  391. select m.dtype, m.thedvalue,m.process_type_name,m.app_id,ia.ITM_APP_NAME,m.serve_area,m.serve_department,m.serve_firm, 'SUM', '件', 'total_works_noend' as 'kind', total_works_noend as 'value'
  392. from bi_work_flow_group_by_time m
  393. left join itm_app ia on ia.ITM_APP_ID=m.app_id
  394. union all
  395. select m.dtype, m.thedvalue,m.process_type_name,m.app_id,ia.ITM_APP_NAME,m.serve_area,m.serve_department,m.serve_firm, 'SUM', '件', 'total_works_notimeout' as 'kind', total_works_notimeout as 'value'
  396. from bi_work_flow_group_by_time m
  397. left join itm_app ia on ia.ITM_APP_ID=m.app_id
  398. union all
  399. select m.dtype, m.thedvalue,m.process_type_name,m.app_id,ia.ITM_APP_NAME,m.serve_area,m.serve_department,m.serve_firm, 'SUM', '件', 'total_works_timeout' as 'kind', total_works_timeout as 'value'
  400. from bi_work_flow_group_by_time m
  401. left join itm_app ia on ia.ITM_APP_ID=m.app_id
  402. union all
  403. select m.dtype, m.thedvalue,m.process_type_name,m.app_id,ia.ITM_APP_NAME,m.serve_area,m.serve_department,m.serve_firm, 'SUM', '秒', 'total_time_consuming' as 'kind', total_time_consuming as 'value'
  404. from bi_work_flow_group_by_time m
  405. left join itm_app ia on ia.ITM_APP_ID=m.app_id
  406. union all
  407. select m.dtype, m.thedvalue,m.process_type_name,m.app_id,ia.ITM_APP_NAME,m.serve_area,m.serve_department,m.serve_firm, 'AVG', '秒', 'avg_time_consuming' as 'kind', avg_time_consuming as 'value'
  408. from bi_work_flow_group_by_time m
  409. left join itm_app ia on ia.ITM_APP_ID=m.app_id
  410. union all
  411. select m.dtype, m.thedvalue,m.process_type_name,m.app_id,ia.ITM_APP_NAME,m.serve_area,m.serve_department,m.serve_firm, 'AVG', '分', 'satisfaction' as 'kind', satisfaction as 'value'
  412. from bi_work_flow_group_by_time m
  413. left join itm_app ia on ia.ITM_APP_ID=m.app_id
  414. union all
  415. select m.dtype, m.thedvalue,m.process_type_name,m.app_id,ia.ITM_APP_NAME,m.serve_area,m.serve_department,m.serve_firm, 'AVG', '%', 'total_works_notimeout_pct' as 'kind', 100*total_works_notimeout/total_works as 'value'
  416. from bi_work_flow_group_by_time m
  417. left join itm_app ia on ia.ITM_APP_ID=m.app_id
  418. union all
  419. select m.dtype, m.thedvalue,m.process_type_name,m.app_id,ia.ITM_APP_NAME,m.serve_area,m.serve_department,m.serve_firm, 'AVG', '%', 'total_works_timeout_pct' as 'kind', 100*total_works_timeout/total_works as 'value'
  420. from bi_work_flow_group_by_time m
  421. left join itm_app ia on ia.ITM_APP_ID=m.app_id
  422. union all
  423. select m.dtype, m.thedvalue,m.process_type_name,m.app_id,ia.ITM_APP_NAME,m.serve_area,m.serve_department,m.serve_firm, 'AVG', '%', 'total_works_end_pct' as 'kind', 100*total_works_end/total_works as 'value'
  424. from bi_work_flow_group_by_time m
  425. left join itm_app ia on ia.ITM_APP_ID=m.app_id;
  426. -- (3)基础设施监控覆盖率趋势
  427. -- 建表语句
  428. DROP TABLE IF EXISTS `bi_hardware_fugai`;
  429. CREATE TABLE `bi_hardware_fugai` (
  430. `dtype` varchar(5) NOT NULL DEFAULT '' COMMENT '日期类型',
  431. `thedvalue` varchar(20) DEFAULT NULL COMMENT '日期',
  432. `itm_hardware_resources_id` varchar(200) DEFAULT '' COMMENT '告警设备ID',
  433. `itm_hardware_resources_type` varchar(64) DEFAULT NULL COMMENT '设备类型',
  434. `itm_hardware_resources_cntype` varchar(5) DEFAULT '' COMMENT '设备类型中文',
  435. `itm_hardware_resources_areacode` varchar(64) DEFAULT NULL COMMENT '告警设备区域',
  436. `ITM_HARDWARE_RESOURCES_ASSNO` varchar(100) DEFAULT NULL COMMENT '国资编码',
  437. `ITM_HARDWARE_RESOURCES_CODE` varchar(200) DEFAULT NULL COMMENT '设备编码',
  438. `ITM_HARDWARE_RESOURCES_NAME` varchar(255) DEFAULT NULL COMMENT '设备名称',
  439. `ITM_HARDWARE_RESOURCES_IP` varchar(64) DEFAULT NULL COMMENT '设备IP',
  440. `ITM_HARDWARE_RESOURCES_STATUS` varchar(64) DEFAULT NULL COMMENT '设备状态',
  441. `itm_monitor_flag` varchar(64) DEFAULT NULL COMMENT '是否进行监控 0未纳入监控 1纳入监控',
  442. `create_time` datetime DEFAULT NULL COMMENT '创建日期',
  443. `NAME` varchar(512) DEFAULT NULL COMMENT '所属组织',
  444. `resclasscnname` varchar(255) DEFAULT NULL COMMENT '所属类型(网系)',
  445. `UID` varchar(100) DEFAULT NULL COMMENT 'UID 同告警设备ID',
  446. `pinpai` varchar(255) DEFAULT NULL COMMENT '设备品牌',
  447. `xinghao` varchar(255) DEFAULT NULL COMMENT '设备型号',
  448. `mac` varchar(255) DEFAULT NULL COMMENT 'MAC地址',
  449. `guoziguishurenyuan` varchar(255) DEFAULT NULL COMMENT '国资归属人员',
  450. `guoziguishubumen` varchar(255) DEFAULT NULL COMMENT '国资归属部门',
  451. `yunweirenyuan` varchar(255) DEFAULT NULL COMMENT '运维人员',
  452. `ITM_HARDWARE_RESOURCES_NETNAME` varchar(100) DEFAULT NULL,
  453. `cloud` varchar(255) DEFAULT NULL COMMENT '云平台'
  454. ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
  455. truncate table bi_hardware_fugai;
  456. insert into bi_hardware_fugai
  457. select 'MONTH' AS dtype, a.thedvalue, b.itm_hardware_resources_id,b.itm_hardware_resources_type,b.itm_hardware_resources_cntype,b.itm_hardware_resources_areacode,b.ITM_HARDWARE_RESOURCES_ASSNO,b.ITM_HARDWARE_RESOURCES_CODE
  458. ,b.ITM_HARDWARE_RESOURCES_NAME,b.ITM_HARDWARE_RESOURCES_IP,b.ITM_HARDWARE_RESOURCES_STATUS,b.itm_monitor_flag,b.create_time
  459. ,b.NAME,b.resclasscnname,b.UID,b.pinpai,b.xinghao,b.mac
  460. ,b.guoziguishurenyuan,b.guoziguishubumen,b.yunweirenyuan,b.NET_NAME as ITM_HARDWARE_RESOURCES_NETNAME,b.cloud from (
  461. select distinct date_format(dt_d,'%Y%m') as thedvalue from bi_m_date where dt_d >= '2021-01-01' and dt_d < '2023-12-31') a
  462. left join bi_itm_hardware_resources b
  463. on a.thedvalue >= date_format(b.create_time,'%Y%m')
  464. UNION ALL
  465. select 'YEAR' AS dtype, a.thedvalue, b.itm_hardware_resources_id,b.itm_hardware_resources_type,b.itm_hardware_resources_cntype,b.itm_hardware_resources_areacode,b.ITM_HARDWARE_RESOURCES_ASSNO,b.ITM_HARDWARE_RESOURCES_CODE
  466. ,b.ITM_HARDWARE_RESOURCES_NAME,b.ITM_HARDWARE_RESOURCES_IP,b.ITM_HARDWARE_RESOURCES_STATUS,b.itm_monitor_flag,b.create_time
  467. ,b.NAME,b.resclasscnname,b.UID,b.pinpai,b.xinghao,b.mac
  468. ,b.guoziguishurenyuan,b.guoziguishubumen,b.yunweirenyuan,b.NET_NAME as ITM_HARDWARE_RESOURCES_NETNAME,b.cloud from (
  469. select distinct date_format(dt_d,'%Y') as thedvalue from bi_m_date where dt_d >= '2021-01-01' and dt_d < '2023-12-31') a
  470. left join bi_itm_hardware_resources b
  471. on a.thedvalue >= date_format(b.create_time,'%Y')
  472. UNION ALL
  473. select 'DAY' AS dtype, a.thedvalue, b.itm_hardware_resources_id,b.itm_hardware_resources_type,b.itm_hardware_resources_cntype,b.itm_hardware_resources_areacode,b.ITM_HARDWARE_RESOURCES_ASSNO,b.ITM_HARDWARE_RESOURCES_CODE
  474. ,b.ITM_HARDWARE_RESOURCES_NAME,b.ITM_HARDWARE_RESOURCES_IP,b.ITM_HARDWARE_RESOURCES_STATUS,b.itm_monitor_flag,b.create_time
  475. ,b.NAME,b.resclasscnname,b.UID,b.pinpai,b.xinghao,b.mac
  476. ,b.guoziguishurenyuan,b.guoziguishubumen,b.yunweirenyuan,b.NET_NAME as ITM_HARDWARE_RESOURCES_NETNAME,b.cloud from (
  477. select distinct date_format(dt_d,'%Y%m%d') as thedvalue from bi_m_date where dt_d >= '2021-01-01' and dt_d < '2023-12-31') a
  478. left join bi_itm_hardware_resources b
  479. on a.thedvalue >= date_format(b.create_time,'%Y%m%d');
  480. -- (4)基础设施资源利用率趋势、服务器资源负载趋势、网络设备带宽利用率趋势、网络设备效能分析、磁盘性能分析、存储设备资源利用率趋势
  481. -- 建表语句
  482. DROP TABLE IF EXISTS `bi_app_stat_group_by_time`;
  483. CREATE TABLE `bi_app_stat_group_by_time` (
  484. `dtype` varchar(5) NOT NULL DEFAULT '' COMMENT '日期类型',
  485. `thedvalue` varchar(15) DEFAULT NULL COMMENT '日期',
  486. `dhour` varchar(15) DEFAULT NULL COMMENT '小时',
  487. `itm_hardware_resources_id` varchar(200) NOT NULL DEFAULT '' COMMENT '告警设备ID',
  488. `itm_hardware_resources_type` varchar(64) DEFAULT NULL COMMENT '设备类型',
  489. `itm_hardware_resources_cntype` varchar(5) NOT NULL DEFAULT '' COMMENT '设备类型中文',
  490. `QGorZG` varchar(10) DEFAULT NULL COMMENT '全国/最高',
  491. `itm_hardware_resources_areacode` varchar(64) DEFAULT NULL COMMENT '告警设备区域',
  492. `ITM_HARDWARE_RESOURCES_ASSNO` varchar(100) DEFAULT NULL COMMENT '国资编码',
  493. `ITM_HARDWARE_RESOURCES_CODE` varchar(200) DEFAULT NULL COMMENT '设备编码',
  494. `ITM_HARDWARE_RESOURCES_NAME` varchar(255) DEFAULT NULL COMMENT '设备名称',
  495. `ITM_HARDWARE_RESOURCES_IP` varchar(64) DEFAULT NULL COMMENT '设备IP',
  496. `ITM_HARDWARE_RESOURCES_STATUS` varchar(64) DEFAULT NULL COMMENT '设备状态',
  497. `ITM_HARDWARE_RESOURCES_NETNAME` varchar(255) DEFAULT NULL COMMENT '网系名称',
  498. `itm_monitor_flag` varchar(64) DEFAULT NULL COMMENT '是否进行监控 0未纳入监控 1纳入监控',
  499. `create_time` datetime DEFAULT NULL COMMENT '设备创建时间',
  500. `NAME` varchar(512) DEFAULT NULL COMMENT '所属组织',
  501. `resclasscnname` varchar(255) DEFAULT NULL COMMENT '所属类型(网系)',
  502. `UID` varchar(100) DEFAULT NULL COMMENT 'UID 同告警设备ID',
  503. `pinpai` varchar(255) DEFAULT NULL COMMENT '设备品牌',
  504. `xinghao` varchar(255) DEFAULT NULL COMMENT '设备型号',
  505. `mac` varchar(255) DEFAULT NULL COMMENT 'MAC地址',
  506. `guoziguishurenyuan` varchar(255) DEFAULT NULL COMMENT '国资归属人员',
  507. `guoziguishubumen` varchar(255) DEFAULT NULL COMMENT '国资归属部门',
  508. `yunweirenyuan` varchar(255) DEFAULT NULL COMMENT '运维人员',
  509. `IND_VALUE_Network_Cpurate` decimal(20,6) DEFAULT NULL COMMENT 'cpu利用率(原始)',
  510. `IND_VALUE_Network_Cpurate_High` decimal(16,2) DEFAULT NULL COMMENT 'CPU利用率峰值(原始)',
  511. `IND_VALUE_Network_Memrate` decimal(20,6) DEFAULT NULL COMMENT '内存利用率(原始)',
  512. `IND_VALUE_Network_Memrate_High` decimal(16,2) DEFAULT NULL COMMENT '内存利用率峰值(原始)',
  513. `IND_VALUE_HOST_DISK_TOTAL` decimal(38,4) DEFAULT NULL COMMENT '磁盘总大小(原始)',
  514. `IND_VALUE_HOST_DISK_USED` decimal(38,4) DEFAULT NULL COMMENT '已使用磁盘大小(原始)',
  515. `IND_VALUE_HOST_DISK_UTILIZATION` decimal(16,4) DEFAULT NULL COMMENT '磁盘利用率峰值(原始)',
  516. `Band_widthrate` decimal(38,4) DEFAULT NULL COMMENT '实时带宽利用率',
  517. `Bandwidthrate_High` decimal(38,4) DEFAULT NULL COMMENT '带宽峰值用率',
  518. `Network_delay` decimal(38,4) DEFAULT NULL COMMENT '网络时延',
  519. `Network_flow` decimal(38,4) DEFAULT NULL COMMENT '端口流量',
  520. `Network_PacketErrorrate` decimal(38,4) DEFAULT NULL COMMENT '丢包率',
  521. `Network_PacketLossrate` decimal(38,4) DEFAULT NULL COMMENT '错包率',
  522. `Write_rate` decimal(38,4) DEFAULT NULL COMMENT '读写速率',
  523. `network_Ifinrate` decimal(38,4) DEFAULT NULL COMMENT '下行利用率',
  524. `network_Ifortrate` decimal(38,4) DEFAULT NULL COMMENT '上行利用率',
  525. `Device_total` decimal(38,4) DEFAULT NULL COMMENT '设备总量',
  526. `Device_used` decimal(38,4) DEFAULT NULL COMMENT '设备已用容量',
  527. `Device_UTILIZATION` decimal(38,4) DEFAULT NULL COMMENT '资源利用率',
  528. `cloud` varchar(255) DEFAULT NULL COMMENT '云平台',
  529. KEY `bi_app_stat_group_by_time_dtype_IDX` (`dtype`,`thedvalue`) USING BTREE
  530. ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
  531. DROP TABLE IF EXISTS `bi_save_tempbgtime`;
  532. CREATE TABLE `bi_save_tempbgtime` (
  533. `bg_time` varchar(300) DEFAULT NULL
  534. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
  535. drop procedure if exists wk_app_stat_group_by_time;
  536. delimiter $$
  537. create procedure wk_app_stat_group_by_time(in bg_time varchar(300), in ed_time varchar(300))
  538. begin
  539. delete from bi_app_stat_group_by_time where dtype = 'HOUR' and thedvalue >= concat(bg_time,'00') and thedvalue < concat(ed_time,'00');
  540. delete from bi_app_stat_group_by_time where dtype = 'DAY' and thedvalue >= bg_time and thedvalue < ed_time;
  541. delete from bi_app_stat_group_by_time where dtype = 'MONTH' and thedvalue >= date_format(STR_TO_DATE(bg_time,'%Y%m%d'),'%Y%m') and thedvalue <= date_format(DATE_ADD(STR_TO_DATE(ed_time,'%Y%m%d'), INTERVAL -1 day),'%Y%m');
  542. delete from bi_app_stat_group_by_time where dtype = 'YEAR' and thedvalue >= date_format(STR_TO_DATE(bg_time,'%Y%m%d'),'%Y') and thedvalue <= date_format(DATE_ADD(STR_TO_DATE(ed_time,'%Y%m%d'), INTERVAL -1 day),'%Y');
  543. insert into bi_app_stat_group_by_time
  544. select
  545. 'HOUR' as dtype,
  546. date_format(b.IND_VALUE_TIME,'%Y%m%d%H') as thedvalue,
  547. date_format(b.IND_VALUE_TIME,'%H') as dhour,
  548. a.itm_hardware_resources_id,a.itm_hardware_resources_type,a.itm_hardware_resources_cntype,case when a.NAME = '最高人民法院' then '最高' else '全国' end QGorZG,a.itm_hardware_resources_areacode,
  549. a.ITM_HARDWARE_RESOURCES_ASSNO,a.ITM_HARDWARE_RESOURCES_CODE,a.ITM_HARDWARE_RESOURCES_NAME,a.ITM_HARDWARE_RESOURCES_IP,a.ITM_HARDWARE_RESOURCES_STATUS,a.NET_NAME as ITM_HARDWARE_RESOURCES_NETNAME
  550. ,a.itm_monitor_flag,a.create_time,a.NAME,a.resclasscnname,a.UID,a.pinpai,a.xinghao,a.mac
  551. ,a.guoziguishurenyuan,a.guoziguishubumen,a.yunweirenyuan,
  552. avg(b.IND_VALUE_Network_Cpurate) as IND_VALUE_Network_Cpurate,max(b.IND_VALUE_Network_Cpurate_High) as IND_VALUE_Network_Cpurate_High,
  553. avg(IND_VALUE_Network_Memrate) as IND_VALUE_Network_Memrate,max(IND_VALUE_Network_Memrate_High) as IND_VALUE_Network_Memrate_High,
  554. 0.0 as IND_VALUE_HOST_DISK_TOTAL, 0.0 as IND_VALUE_HOST_DISK_USED,0.0 as IND_VALUE_HOST_DISK_UTILIZATION,
  555. avg(IND_VALUE_Network_Bandwidthrate) as Band_widthrate,
  556. max(IND_VALUE_Network_Bandwidthrate_High) as Bandwidthrate_High,
  557. 0 as Network_delay,
  558. avg(TRANSSIZE_Up + TRANSSIZE_Down) as Network_flow,
  559. avg(IND_VALUE_Network_PacketErrorrate) as Network_PacketErrorrate,
  560. avg(IND_VALUE_Network_PacketLossrate) as Network_PacketLossrate,
  561. avg(IND_VALUE_Network_Bandwidthrate) as Write_rate,
  562. avg(IND_VALUE_Network_Ifinrate) as network_Ifinrate,
  563. avg(IND_VALUE_Network_Ifoutrate) as network_Ifortrate,
  564. 0.0 as Device_total,
  565. 0.0 as Device_used,
  566. 0.0 as Device_UTILIZATION,
  567. a.cloud
  568. from bi_itm_hardware_resources a
  569. inner join app_network_stat b
  570. on a.itm_hardware_resources_id = b.INT_ID
  571. where b.IND_VALUE_TIME >= date_format(STR_TO_DATE(bg_time,'%Y%m%d'),'%Y-%m-%d') and b.IND_VALUE_TIME < date_format(STR_TO_DATE(ed_time,'%Y%m%d'),'%Y-%m-%d')
  572. GROUP BY date_format(b.IND_VALUE_TIME,'%Y%m%d%H'),date_format(b.IND_VALUE_TIME,'%H'),
  573. a.itm_hardware_resources_id,a.itm_hardware_resources_type,a.itm_hardware_resources_cntype,case when a.NAME = '最高人民法院' then '最高' else '全国' end,a.itm_hardware_resources_areacode,
  574. a.ITM_HARDWARE_RESOURCES_ASSNO,a.ITM_HARDWARE_RESOURCES_CODE,a.ITM_HARDWARE_RESOURCES_NAME,a.ITM_HARDWARE_RESOURCES_IP,a.ITM_HARDWARE_RESOURCES_STATUS,a.NET_NAME
  575. ,a.itm_monitor_flag,a.create_time,a.NAME,a.resclasscnname,a.UID,a.pinpai,a.xinghao,a.mac
  576. ,a.guoziguishurenyuan,a.guoziguishubumen,a.yunweirenyuan,a.cloud
  577. union all
  578. select
  579. 'HOUR' as dtype,
  580. date_format(b.IND_VALUE_TIME,'%Y%m%d%H') as thedvalue,
  581. date_format(b.IND_VALUE_TIME,'%H') as dhour,
  582. a.itm_hardware_resources_id,a.itm_hardware_resources_type,a.itm_hardware_resources_cntype,case when a.NAME = '最高人民法院' then '最高' else '全国' end as QGorZG,a.itm_hardware_resources_areacode,
  583. a.ITM_HARDWARE_RESOURCES_ASSNO,a.ITM_HARDWARE_RESOURCES_CODE,a.ITM_HARDWARE_RESOURCES_NAME,a.ITM_HARDWARE_RESOURCES_IP,a.ITM_HARDWARE_RESOURCES_STATUS,a.NET_NAME as ITM_HARDWARE_RESOURCES_NETNAME
  584. ,a.itm_monitor_flag,a.create_time,a.NAME,a.resclasscnname,a.UID,a.pinpai,a.xinghao,a.mac
  585. ,a.guoziguishurenyuan,a.guoziguishubumen,a.yunweirenyuan,
  586. 0.0 as IND_VALUE_Network_Cpurate,0.0 as IND_VALUE_Network_Cpurate_High,0.0 as IND_VALUE_Network_Memrate,0.0 as IND_VALUE_Network_Memrate_High,
  587. sum(b.IND_VALUE_HOST_DISK_TOTAL) as IND_VALUE_HOST_DISK_TOTAL, sum(b.IND_VALUE_HOST_DISK_USED) as IND_VALUE_HOST_DISK_USED,
  588. max(b.IND_VALUE_HOST_DISK_UTILIZATION) as IND_VALUE_HOST_DISK_UTILIZATION,
  589. 0.0 as Band_widthrate,
  590. 0.0 as Bandwidthrate_High,
  591. 0.0 as Network_delay,
  592. 0.0 as Network_flow,
  593. 0.0 as Network_PacketErrorrate,
  594. 0.0 as Network_PacketLossrate,
  595. 0.0 as Write_rate,
  596. 0.0 as network_Ifinrate,
  597. 0.0 as network_Ifortrate,
  598. max(IND_VALUE_HOST_DISK_TOTAL) as Device_total,
  599. max(IND_VALUE_HOST_DISK_USED) as Device_used,
  600. max(b.IND_VALUE_HOST_DISK_UTILIZATION) as Device_UTILIZATION,
  601. a.cloud
  602. from bi_itm_hardware_resources a
  603. inner join app_host_stat b
  604. on a.itm_hardware_resources_id = b.INT_ID
  605. where b.IND_VALUE_TIME >= date_format(STR_TO_DATE(bg_time,'%Y%m%d'),'%Y-%m-%d') and b.IND_VALUE_TIME < date_format(STR_TO_DATE(ed_time,'%Y%m%d'),'%Y-%m-%d')
  606. GROUP BY date_format(b.IND_VALUE_TIME,'%Y%m%d%H'),date_format(b.IND_VALUE_TIME,'%H'),
  607. a.itm_hardware_resources_id,a.itm_hardware_resources_type,a.itm_hardware_resources_cntype,case when a.NAME = '最高人民法院' then '最高' else '全国' end,a.itm_hardware_resources_areacode,
  608. a.ITM_HARDWARE_RESOURCES_ASSNO,a.ITM_HARDWARE_RESOURCES_CODE,a.ITM_HARDWARE_RESOURCES_NAME,a.ITM_HARDWARE_RESOURCES_IP,a.ITM_HARDWARE_RESOURCES_STATUS,a.NET_NAME
  609. ,a.itm_monitor_flag,a.CREATE_TIME,a.NAME,a.resclasscnname,a.UID,a.pinpai,a.xinghao,a.mac
  610. ,a.guoziguishurenyuan,a.guoziguishubumen,a.yunweirenyuan,a.cloud;
  611. insert into bi_app_stat_group_by_time
  612. select
  613. 'DAY' as dtype,
  614. substr(thedvalue,1,8) as thedvalue,
  615. dhour ,itm_hardware_resources_id ,itm_hardware_resources_type ,itm_hardware_resources_cntype ,QGorZG ,itm_hardware_resources_areacode ,
  616. ITM_HARDWARE_RESOURCES_ASSNO ,ITM_HARDWARE_RESOURCES_CODE ,ITM_HARDWARE_RESOURCES_NAME ,ITM_HARDWARE_RESOURCES_IP ,ITM_HARDWARE_RESOURCES_STATUS ,
  617. ITM_HARDWARE_RESOURCES_NETNAME ,itm_monitor_flag ,create_time ,NAME ,resclasscnname ,UID ,pinpai ,xinghao ,mac ,guoziguishurenyuan ,guoziguishubumen ,yunweirenyuan,
  618. avg(IND_VALUE_Network_Cpurate) as IND_VALUE_Network_Cpurate,max(IND_VALUE_Network_Cpurate_High) as IND_VALUE_Network_Cpurate_High,
  619. avg(IND_VALUE_Network_Memrate) as IND_VALUE_Network_Memrate,max(IND_VALUE_Network_Memrate_High) as IND_VALUE_Network_Memrate_High,
  620. sum(IND_VALUE_HOST_DISK_TOTAL) as IND_VALUE_HOST_DISK_TOTAL, sum(IND_VALUE_HOST_DISK_USED) as IND_VALUE_HOST_DISK_USED,
  621. max(IND_VALUE_HOST_DISK_UTILIZATION) as IND_VALUE_HOST_DISK_UTILIZATION,
  622. avg(Band_widthrate) as Band_widthrate,
  623. max(Bandwidthrate_High) as Bandwidthrate_High,
  624. 0 as Network_delay,
  625. 0 as Network_flow,
  626. avg(Network_PacketErrorrate) as Network_PacketErrorrate,
  627. avg(Network_PacketLossrate) as Network_PacketLossrate,
  628. 0 as Write_rate,
  629. avg(network_Ifinrate) as network_Ifinrate,
  630. avg(network_Ifortrate) as network_Ifortrate,
  631. max(Device_total) as Device_total,
  632. max(Device_used) as Device_used,
  633. max(Device_UTILIZATION) as Device_UTILIZATION,
  634. cloud
  635. from bi_app_stat_group_by_time
  636. where dtype = 'HOUR' and thedvalue >= concat(bg_time,'00') and thedvalue < concat(ed_time,'00')
  637. group by substr(thedvalue,1,8),dhour ,itm_hardware_resources_id ,itm_hardware_resources_type ,itm_hardware_resources_cntype ,QGorZG ,itm_hardware_resources_areacode ,
  638. ITM_HARDWARE_RESOURCES_ASSNO ,ITM_HARDWARE_RESOURCES_CODE ,ITM_HARDWARE_RESOURCES_NAME ,ITM_HARDWARE_RESOURCES_IP ,ITM_HARDWARE_RESOURCES_STATUS ,
  639. ITM_HARDWARE_RESOURCES_NETNAME ,itm_monitor_flag ,create_time ,NAME ,resclasscnname ,UID ,pinpai ,xinghao ,mac ,guoziguishurenyuan ,guoziguishubumen ,yunweirenyuan, cloud;
  640. insert into bi_app_stat_group_by_time
  641. select
  642. 'MONTH' as dtype,
  643. substr(thedvalue,1,6) as thedvalue,
  644. dhour ,itm_hardware_resources_id ,itm_hardware_resources_type ,itm_hardware_resources_cntype ,QGorZG ,itm_hardware_resources_areacode ,
  645. ITM_HARDWARE_RESOURCES_ASSNO ,ITM_HARDWARE_RESOURCES_CODE ,ITM_HARDWARE_RESOURCES_NAME ,ITM_HARDWARE_RESOURCES_IP ,ITM_HARDWARE_RESOURCES_STATUS ,
  646. ITM_HARDWARE_RESOURCES_NETNAME ,itm_monitor_flag ,create_time ,NAME ,resclasscnname ,UID ,pinpai ,xinghao ,mac ,guoziguishurenyuan ,guoziguishubumen ,yunweirenyuan,
  647. avg(IND_VALUE_Network_Cpurate) as IND_VALUE_Network_Cpurate,max(IND_VALUE_Network_Cpurate_High) as IND_VALUE_Network_Cpurate_High,
  648. avg(IND_VALUE_Network_Memrate) as IND_VALUE_Network_Memrate,max(IND_VALUE_Network_Memrate_High) as IND_VALUE_Network_Memrate_High,
  649. sum(IND_VALUE_HOST_DISK_TOTAL) as IND_VALUE_HOST_DISK_TOTAL, sum(IND_VALUE_HOST_DISK_USED) as IND_VALUE_HOST_DISK_USED,
  650. max(IND_VALUE_HOST_DISK_UTILIZATION) as IND_VALUE_HOST_DISK_UTILIZATION,
  651. avg(Band_widthrate) as Band_widthrate,
  652. max(Bandwidthrate_High) as Bandwidthrate_High,
  653. 0 as Network_delay,
  654. 0 as Network_flow,
  655. avg(Network_PacketErrorrate) as Network_PacketErrorrate,
  656. avg(Network_PacketLossrate) as Network_PacketLossrate,
  657. 0 as Write_rate,
  658. avg(network_Ifinrate) as network_Ifinrate,
  659. avg(network_Ifortrate) as network_Ifortrate,
  660. max(Device_total) as Device_total,
  661. max(Device_used) as Device_used,
  662. max(Device_UTILIZATION) as Device_UTILIZATION,
  663. cloud
  664. from bi_app_stat_group_by_time
  665. where dtype = 'DAY' and thedvalue >= bg_time and thedvalue < ed_time
  666. group by substr(thedvalue,1,6),dhour ,itm_hardware_resources_id ,itm_hardware_resources_type ,itm_hardware_resources_cntype ,QGorZG ,itm_hardware_resources_areacode ,
  667. ITM_HARDWARE_RESOURCES_ASSNO ,ITM_HARDWARE_RESOURCES_CODE ,ITM_HARDWARE_RESOURCES_NAME ,ITM_HARDWARE_RESOURCES_IP ,ITM_HARDWARE_RESOURCES_STATUS ,
  668. ITM_HARDWARE_RESOURCES_NETNAME ,itm_monitor_flag ,create_time ,NAME ,resclasscnname ,UID ,pinpai ,xinghao ,mac ,guoziguishurenyuan ,guoziguishubumen ,yunweirenyuan, cloud;
  669. insert into bi_app_stat_group_by_time
  670. select
  671. 'YEAR' as dtype,
  672. substr(thedvalue,1,4) as thedvalue,
  673. dhour ,itm_hardware_resources_id ,itm_hardware_resources_type ,itm_hardware_resources_cntype ,QGorZG ,itm_hardware_resources_areacode ,
  674. ITM_HARDWARE_RESOURCES_ASSNO ,ITM_HARDWARE_RESOURCES_CODE ,ITM_HARDWARE_RESOURCES_NAME ,ITM_HARDWARE_RESOURCES_IP ,ITM_HARDWARE_RESOURCES_STATUS ,
  675. ITM_HARDWARE_RESOURCES_NETNAME ,itm_monitor_flag ,create_time ,NAME ,resclasscnname ,UID ,pinpai ,xinghao ,mac ,guoziguishurenyuan ,guoziguishubumen ,yunweirenyuan,
  676. avg(IND_VALUE_Network_Cpurate) as IND_VALUE_Network_Cpurate,max(IND_VALUE_Network_Cpurate_High) as IND_VALUE_Network_Cpurate_High,
  677. avg(IND_VALUE_Network_Memrate) as IND_VALUE_Network_Memrate,max(IND_VALUE_Network_Memrate_High) as IND_VALUE_Network_Memrate_High,
  678. sum(IND_VALUE_HOST_DISK_TOTAL) as IND_VALUE_HOST_DISK_TOTAL, sum(IND_VALUE_HOST_DISK_USED) as IND_VALUE_HOST_DISK_USED,
  679. max(IND_VALUE_HOST_DISK_UTILIZATION) as IND_VALUE_HOST_DISK_UTILIZATION,
  680. avg(Band_widthrate) as Band_widthrate,
  681. max(Bandwidthrate_High) as Bandwidthrate_High,
  682. 0 as Network_delay,
  683. 0 as Network_flow,
  684. avg(Network_PacketErrorrate) as Network_PacketErrorrate,
  685. avg(Network_PacketLossrate) as Network_PacketLossrate,
  686. 0 as Write_rate,
  687. avg(network_Ifinrate) as network_Ifinrate,
  688. avg(network_Ifortrate) as network_Ifortrate,
  689. max(Device_total) as Device_total,
  690. max(Device_used) as Device_used,
  691. max(Device_UTILIZATION) as Device_UTILIZATION,
  692. cloud
  693. from bi_app_stat_group_by_time
  694. where dtype = 'MONTH' and thedvalue >= date_format(STR_TO_DATE(bg_time,'%Y%m%d'),'%Y%m') and thedvalue <= date_format(DATE_ADD(STR_TO_DATE(ed_time,'%Y%m%d'), INTERVAL -1 day),'%Y%m')
  695. group by substr(thedvalue,1,4),dhour ,itm_hardware_resources_id ,itm_hardware_resources_type ,itm_hardware_resources_cntype ,QGorZG ,itm_hardware_resources_areacode ,
  696. ITM_HARDWARE_RESOURCES_ASSNO ,ITM_HARDWARE_RESOURCES_CODE ,ITM_HARDWARE_RESOURCES_NAME ,ITM_HARDWARE_RESOURCES_IP ,ITM_HARDWARE_RESOURCES_STATUS ,
  697. ITM_HARDWARE_RESOURCES_NETNAME ,itm_monitor_flag ,create_time ,NAME ,resclasscnname ,UID ,pinpai ,xinghao ,mac ,guoziguishurenyuan ,guoziguishubumen ,yunweirenyuan, cloud;
  698. end $$
  699. delimiter ;
  700. -- 循环执行(按天循环运行,并将执行完成的结果插入bi_save_tempbgtime)
  701. drop procedure if exists wk_app_stat_group_by_time_xunhuan;
  702. delimiter $$
  703. create procedure wk_app_stat_group_by_time_xunhuan(in bg_time varchar(300), in ed_time varchar(300))
  704. begin
  705. declare i varchar(300);
  706. set i = bg_time;
  707. while i < ed_time do
  708. call wk_app_stat_group_by_time(i, date_format(DATE_ADD(STR_TO_DATE(i,'%Y%m%d'), INTERVAL 1 day),'%Y%m%d'));
  709. insert into bi_save_tempbgtime values(i);
  710. set i = date_format(DATE_ADD(STR_TO_DATE(i,'%Y%m%d'), INTERVAL 1 day),'%Y%m%d');
  711. end while;
  712. end $$
  713. delimiter ;
  714. -- 按时间段一次运行(只包含开始时间,不包含结束时间,输入格式为20230801这种格式)
  715. truncate table bi_save_tempbgtime;
  716. call wk_app_stat_group_by_time_xunhuan('20230101','20231230');
  717. -- (5)四级法院网络中断趋势
  718. -- 建表语句
  719. DROP TABLE IF EXISTS `bi_pub_organ_siji`;
  720. CREATE TABLE `bi_pub_organ_siji` (
  721. `ID` varchar(32) DEFAULT NULL,
  722. `CODE` varchar(64) DEFAULT NULL,
  723. `FYJB1` varchar(512) DEFAULT NULL,
  724. `FYJB2` varchar(512) DEFAULT NULL,
  725. `FYJB3` varchar(512) DEFAULT NULL,
  726. `FYJB4` varchar(512) DEFAULT NULL,
  727. `FYJB1_CODE` varchar(32) CHARACTER SET utf8 COLLATE utf8_bin DEFAULT NULL,
  728. `FYJB2_CODE` varchar(32) CHARACTER SET utf8 COLLATE utf8_bin DEFAULT NULL,
  729. `FYJB3_CODE` varchar(32) CHARACTER SET utf8 COLLATE utf8_bin DEFAULT NULL,
  730. `FYJB4_CODE` varchar(32) CHARACTER SET utf8 COLLATE utf8_bin NOT NULL DEFAULT '',
  731. `organ_type` varchar(6) NOT NULL DEFAULT '',
  732. `COURT_NUM` varchar(255) DEFAULT NULL,
  733. `COURT_TYPE` varchar(36) DEFAULT NULL,
  734. `SHORT_NAME` varchar(255) DEFAULT NULL,
  735. `STATUS` char(1) DEFAULT NULL,
  736. `PUB_LONGITUDE` varchar(255) DEFAULT NULL,
  737. `PUB_LATITUDE` varchar(255) DEFAULT NULL,
  738. `PUB_ORGAN_IP` varchar(100) DEFAULT NULL,
  739. `FYJB1_JC` varchar(512) DEFAULT NULL,
  740. `FYJB2_JC` varchar(512) DEFAULT NULL,
  741. `FYJB3_JC` varchar(512) DEFAULT NULL,
  742. `FYJB4_JC` varchar(512) DEFAULT NULL,
  743. KEY `index_1` (`CODE`) USING BTREE,
  744. KEY `index_2` (`FYJB2`) USING BTREE,
  745. KEY `index_3` (`FYJB3`) USING BTREE,
  746. KEY `index_4` (`FYJB4`) USING BTREE,
  747. KEY `index_5` (`FYJB2_JC`) USING BTREE,
  748. KEY `index_6` (`FYJB3_JC`) USING BTREE,
  749. KEY `index_7` (`FYJB4_JC`) USING BTREE
  750. ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
  751. truncate table bi_pub_organ_siji;
  752. insert into bi_pub_organ_siji
  753. select
  754. m.ID,m.CODE,m.NAME AS FYJB1,'-' as FYJB2,'-' as FYJB3,'-' as FYJB4,a.org_code as FYJB1_CODE,'-' as FYJB2_CODE,'-' as FYJB3_CODE,'-' as FYJB4_CODE,
  755. 'FYJB.1' as organ_type,m.COURT_NUM,m.COURT_TYPE,m.SHORT_NAME,m.STATUS,m.PUB_LONGITUDE,m.PUB_LATITUDE,m.PUB_ORGAN_IP,
  756. m.SHORT_NAME AS FYJB1_JC,'-' as FYJB2_JC,'-' as FYJB3_JC,'-' as FYJB4_JC
  757. from pub_organ_tree a
  758. left join pub_organ m
  759. on a.org_code = m.code
  760. where a.parent_code = '0'
  761. union all
  762. select
  763. m.ID,m.CODE,l.NAME AS FYJB1,m.NAME as FYJB2,'-' as FYJB3,'-' as FYJB4,b.org_code as FYJB1_CODE,a.org_code as FYJB2_CODE,'-' as FYJB3_CODE,'-' as FYJB4_CODE,
  764. 'FYJB.2' as organ_type,m.COURT_NUM,m.COURT_TYPE,m.SHORT_NAME,m.STATUS,m.PUB_LONGITUDE,m.PUB_LATITUDE,m.PUB_ORGAN_IP,
  765. l.SHORT_NAME AS FYJB1_JC,m.SHORT_NAME as FYJB2_JC,'-' as FYJB3_JC,'-' as FYJB4_JC
  766. from pub_organ_tree a
  767. left join pub_organ_tree b
  768. on a.parent_code = b.org_code
  769. left join pub_organ l
  770. on b.org_code = l.code
  771. left join pub_organ m
  772. on a.org_code = m.code
  773. where b.parent_code = '0'
  774. union all
  775. select
  776. m.ID,m.CODE,k.NAME AS FYJB1,l.NAME as FYJB2,m.NAME as FYJB3,'-' as FYJB4,c.org_code as FYJB1_CODE,b.org_code as FYJB2_CODE,a.org_code as FYJB3_CODE,'-' as FYJB4_CODE,
  777. 'FYJB.3' as organ_type,m.COURT_NUM,m.COURT_TYPE,m.SHORT_NAME,m.STATUS,m.PUB_LONGITUDE,m.PUB_LATITUDE,m.PUB_ORGAN_IP,
  778. k.SHORT_NAME AS FYJB1_JC,l.SHORT_NAME as FYJB2_JC,m.SHORT_NAME as FYJB3_JC,'-' as FYJB4_JC
  779. from pub_organ_tree a
  780. left join pub_organ_tree b
  781. on a.parent_code = b.org_code
  782. left join pub_organ_tree c
  783. on b.parent_code = c.org_code
  784. left join pub_organ k
  785. on c.org_code = k.code
  786. left join pub_organ l
  787. on b.org_code = l.code
  788. left join pub_organ m
  789. on a.org_code = m.code
  790. where c.parent_code = '0'
  791. union all
  792. select
  793. m.ID,m.CODE,j.NAME AS FYJB1,k.NAME as FYJB2,l.NAME as FYJB3,m.NAME as FYJB4,d.org_code as FYJB1_CODE,c.org_code as FYJB2_CODE,b.org_code as FYJB3_CODE,a.org_code as FYJB4_CODE,
  794. 'FYJB.4' as organ_type,m.COURT_NUM,m.COURT_TYPE,m.SHORT_NAME,m.STATUS,m.PUB_LONGITUDE,m.PUB_LATITUDE,m.PUB_ORGAN_IP,
  795. j.SHORT_NAME AS FYJB1_JC,k.SHORT_NAME as FYJB2_JC,l.SHORT_NAME as FYJB3_JC,m.SHORT_NAME as FYJB4_JC
  796. from pub_organ_tree a
  797. left join pub_organ_tree b
  798. on a.parent_code = b.org_code
  799. left join pub_organ_tree c
  800. on b.parent_code = c.org_code
  801. left join pub_organ_tree d
  802. on c.parent_code = d.org_code
  803. left join pub_organ j
  804. on d.org_code = j.code
  805. left join pub_organ k
  806. on c.org_code = k.code
  807. left join pub_organ l
  808. on b.org_code = l.code
  809. left join pub_organ m
  810. on a.org_code = m.code
  811. where d.parent_code = '0';
  812. -- 建表语句
  813. DROP TABLE IF EXISTS `bi_sijifayuan_alm_group_by_time`;
  814. CREATE TABLE `bi_sijifayuan_alm_group_by_time` (
  815. `dtype` varchar(5) NOT NULL DEFAULT '' COMMENT '日期类型',
  816. `thedvalue` varchar(15) DEFAULT NULL COMMENT '日期',
  817. `dhour` varchar(7) DEFAULT NULL COMMENT '日期',
  818. `alarm_object_id` varchar(64) DEFAULT NULL COMMENT '告警ID(网络CODE)',
  819. `alarm_object_ip` varchar(300) DEFAULT NULL COMMENT '告警IP(网络IP)',
  820. `alarm_object_type` varchar(6) NOT NULL DEFAULT '' COMMENT '告警对象类型',
  821. `severity_type` varchar(2) NOT NULL DEFAULT '' COMMENT '告警级别',
  822. `title` varchar(256) DEFAULT NULL COMMENT '告警标题',
  823. `alarm_text` mediumtext COMMENT '告警标题',
  824. `is_active_alarm` bigint(20) NOT NULL DEFAULT '0' COMMENT '告警正文',
  825. `FYJB1` varchar(512) DEFAULT NULL COMMENT '1级法院名称',
  826. `FYJB2` varchar(512) DEFAULT NULL COMMENT '2级法院名称',
  827. `FYJB3` varchar(512) DEFAULT NULL COMMENT '3级法院名称',
  828. `FYJB4` varchar(512) DEFAULT NULL COMMENT '4级法院名称',
  829. `FYJB1_CODE` varchar(32) CHARACTER SET utf8 COLLATE utf8_bin DEFAULT NULL COMMENT '1级法院CODE',
  830. `FYJB2_CODE` varchar(32) CHARACTER SET utf8 COLLATE utf8_bin DEFAULT NULL COMMENT '2级法院CODE',
  831. `FYJB3_CODE` varchar(32) CHARACTER SET utf8 COLLATE utf8_bin DEFAULT NULL COMMENT '3级法院CODE',
  832. `FYJB4_CODE` varchar(32) CHARACTER SET utf8 COLLATE utf8_bin DEFAULT NULL COMMENT '4级法院CODE',
  833. `organ_type` varchar(6) DEFAULT NULL COMMENT '法院级别',
  834. `COURT_NUM` varchar(255) DEFAULT NULL,
  835. `COURT_TYPE` varchar(36) DEFAULT NULL,
  836. `SHORT_NAME` varchar(255) DEFAULT NULL,
  837. `STATUS` char(1) DEFAULT NULL,
  838. `PUB_LONGITUDE` varchar(255) DEFAULT NULL,
  839. `PUB_LATITUDE` varchar(255) DEFAULT NULL,
  840. `PUB_ORGAN_IP` varchar(100) DEFAULT NULL,
  841. `alarm_count` double DEFAULT NULL COMMENT '告警次数',
  842. `alarm_time` decimal(65,5) DEFAULT NULL COMMENT '告警时长',
  843. `alarm_zy_num` decimal(42,0) DEFAULT NULL COMMENT '中断次数(故障次数)',
  844. `total_zy_num` decimal(24,4) DEFAULT NULL COMMENT '总资产数(取平均)',
  845. `pingall` double(17,0) DEFAULT NULL COMMENT 'ping次数',
  846. `pingdown` double(17,0) DEFAULT NULL COMMENT 'ping不通次数'
  847. ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
  848. truncate table bi_sijifayuan_alm_group_by_time;
  849. insert into bi_sijifayuan_alm_group_by_time
  850. select
  851. 'HOUR' AS dtype,
  852. date_format(occur_time,'%Y%m%d%H') as thedvalue,
  853. date_format(occur_time,'%H') as dhour,
  854. alarm_object_id,
  855. alarm_object_ip,
  856. alarm_object_type,severity_type,
  857. title,
  858. alarm_text,
  859. is_active_alarm,
  860. FYJB1,FYJB2,FYJB3,FYJB4,FYJB1_CODE,FYJB2_CODE,FYJB3_CODE,FYJB4_CODE,organ_type,COURT_NUM,COURT_TYPE,SHORT_NAME,STATUS,PUB_LONGITUDE,PUB_LATITUDE,PUB_ORGAN_IP,
  861. sum(alarm_count) as alarm_count,
  862. sum(alarm_time) as alarm_time,
  863. count(1) as alarm_zy_num,
  864. (select count(1) from bi_itm_hardware_resources where itm_hardware_resources_cntype != '非资产设备') as total_zy_num,
  865. 0 as pingall,
  866. 0 as pingdown
  867. from (
  868. select
  869. a.occur_time,
  870. a.alarm_object_id,
  871. a.alarm_object_ip,
  872. a.alarm_object_type,
  873. case a.severity_id when 1 then '致命' when 2 then '严重' when 3 then '一般' else '未知' end as severity_type,
  874. a.title,
  875. a.alarm_text,
  876. a.is_active_alarm,
  877. a.alarm_count,
  878. timestampdiff(MINUTE,a.occur_time,a.end_time)*1.0/60 as alarm_time,
  879. b.FYJB1,b.FYJB2,b.FYJB3,b.FYJB4,b.FYJB1_CODE,b.FYJB2_CODE,b.FYJB3_CODE,b.FYJB4_CODE,b.organ_type,b.COURT_NUM,b.COURT_TYPE,b.SHORT_NAME,b.STATUS,b.PUB_LONGITUDE,b.PUB_LATITUDE,b.PUB_ORGAN_IP
  880. from (select * from v_bi_alm_all_alarm where alarm_object_type in ('网络','路由器','交换机')) a
  881. left join bi_pub_organ_siji b
  882. on a.alarm_object_id = b.CODE) m
  883. group by
  884. date_format(occur_time,'%Y%m%d%H') ,
  885. date_format(occur_time,'%H') ,
  886. alarm_object_id,
  887. alarm_object_ip,
  888. alarm_object_type,severity_type,
  889. title,
  890. alarm_text,
  891. is_active_alarm,
  892. FYJB1,FYJB2,FYJB3,FYJB4,FYJB1_CODE,FYJB2_CODE,FYJB3_CODE,FYJB4_CODE,organ_type,COURT_NUM,COURT_TYPE,SHORT_NAME,STATUS,PUB_LONGITUDE,PUB_LATITUDE,PUB_ORGAN_IP;
  893. insert into bi_sijifayuan_alm_group_by_time
  894. select
  895. 'DAY' AS dtype,
  896. substring(thedvalue,1,8) AS thedvalue,
  897. dhour as dhour,
  898. alarm_object_id,
  899. alarm_object_ip,
  900. alarm_object_type,severity_type,
  901. title,
  902. alarm_text,
  903. is_active_alarm,
  904. FYJB1,FYJB2,FYJB3,FYJB4,FYJB1_CODE,FYJB2_CODE,FYJB3_CODE,FYJB4_CODE,organ_type,COURT_NUM,COURT_TYPE,SHORT_NAME,STATUS,PUB_LONGITUDE,PUB_LATITUDE,PUB_ORGAN_IP,
  905. sum(alarm_count) as alarm_count,
  906. sum(alarm_time) as alarm_time,
  907. SUM(alarm_zy_num) as alarm_zy_num,
  908. AVG(total_zy_num) as total_zy_num,
  909. SUM(pingall) as pingall,
  910. SUM(pingdown) as pingdown
  911. FROM bi_sijifayuan_alm_group_by_time
  912. where dtype = 'HOUR'
  913. GROUP BY
  914. substring(thedvalue,1,8),
  915. dhour,
  916. alarm_object_id,
  917. alarm_object_ip,
  918. alarm_object_type,severity_type,
  919. title,
  920. alarm_text,
  921. is_active_alarm,
  922. FYJB1,FYJB2,FYJB3,FYJB4,FYJB1_CODE,FYJB2_CODE,FYJB3_CODE,FYJB4_CODE,organ_type,COURT_NUM,COURT_TYPE,SHORT_NAME,STATUS,PUB_LONGITUDE,PUB_LATITUDE,PUB_ORGAN_IP;
  923. insert into bi_sijifayuan_alm_group_by_time
  924. select
  925. 'MONTH' AS dtype,
  926. substring(thedvalue,1,6) AS thedvalue,
  927. dhour as dhour,
  928. alarm_object_id,
  929. alarm_object_ip,
  930. alarm_object_type,severity_type,
  931. title,
  932. alarm_text,
  933. is_active_alarm,
  934. FYJB1,FYJB2,FYJB3,FYJB4,FYJB1_CODE,FYJB2_CODE,FYJB3_CODE,FYJB4_CODE,organ_type,COURT_NUM,COURT_TYPE,SHORT_NAME,STATUS,PUB_LONGITUDE,PUB_LATITUDE,PUB_ORGAN_IP,
  935. sum(alarm_count) as alarm_count,
  936. sum(alarm_time) as alarm_time,
  937. SUM(alarm_zy_num) as alarm_zy_num,
  938. AVG(total_zy_num) as total_zy_num,
  939. SUM(pingall) as pingall,
  940. SUM(pingdown) as pingdown
  941. FROM bi_sijifayuan_alm_group_by_time
  942. where dtype = 'DAY'
  943. GROUP BY
  944. substring(thedvalue,1,6),
  945. dhour,
  946. alarm_object_id,
  947. alarm_object_ip,
  948. alarm_object_type,severity_type,
  949. title,
  950. alarm_text,
  951. is_active_alarm,
  952. FYJB1,FYJB2,FYJB3,FYJB4,FYJB1_CODE,FYJB2_CODE,FYJB3_CODE,FYJB4_CODE,organ_type,COURT_NUM,COURT_TYPE,SHORT_NAME,STATUS,PUB_LONGITUDE,PUB_LATITUDE,PUB_ORGAN_IP;
  953. insert into bi_sijifayuan_alm_group_by_time
  954. select
  955. 'YEAR' AS dtype,
  956. substring(thedvalue,1,4) AS thedvalue,
  957. dhour as dhour,
  958. alarm_object_id,
  959. alarm_object_ip,
  960. alarm_object_type,severity_type,
  961. title,
  962. alarm_text,
  963. is_active_alarm,
  964. FYJB1,FYJB2,FYJB3,FYJB4,FYJB1_CODE,FYJB2_CODE,FYJB3_CODE,FYJB4_CODE,organ_type,COURT_NUM,COURT_TYPE,SHORT_NAME,STATUS,PUB_LONGITUDE,PUB_LATITUDE,PUB_ORGAN_IP,
  965. sum(alarm_count) as alarm_count,
  966. sum(alarm_time) as alarm_time,
  967. SUM(alarm_zy_num) as alarm_zy_num,
  968. AVG(total_zy_num) as total_zy_num,
  969. SUM(pingall) as pingall,
  970. SUM(pingdown) as pingdown
  971. FROM bi_sijifayuan_alm_group_by_time
  972. where dtype = 'MONTH'
  973. GROUP BY
  974. substring(thedvalue,1,4),
  975. dhour,
  976. alarm_object_id,
  977. alarm_object_ip,
  978. alarm_object_type,severity_type,
  979. title,
  980. alarm_text,
  981. is_active_alarm,
  982. FYJB1,FYJB2,FYJB3,FYJB4,FYJB1_CODE,FYJB2_CODE,FYJB3_CODE,FYJB4_CODE,organ_type,COURT_NUM,COURT_TYPE,SHORT_NAME,STATUS,PUB_LONGITUDE,PUB_LATITUDE,PUB_ORGAN_IP;
  983. -- (6) 虚拟化资源分配趋势、虚拟化资源使用趋势
  984. -- 建表语句
  985. DROP TABLE IF EXISTS `bi_host_stat`;
  986. CREATE TABLE `bi_host_stat` (
  987. `dtype` VARCHAR ( 10 ) NOT NULL DEFAULT '',
  988. `thedvalue` VARCHAR ( 10 ) DEFAULT NULL,
  989. `COMPANY` VARCHAR ( 30 ) DEFAULT NULL COMMENT '数据来源',
  990. `target` VARCHAR ( 20 ) NOT NULL DEFAULT '',
  991. `dim` VARCHAR ( 20 ) NOT NULL DEFAULT '',
  992. `dim_value` DECIMAL ( 50, 20 ) DEFAULT NULL,
  993. `group_agg` VARCHAR ( 10 ) NOT NULL DEFAULT '',
  994. `unit` VARCHAR ( 10 ) NOT NULL DEFAULT '单位' ,
  995. `cloud` varchar(255) DEFAULT NULL COMMENT '云平台'
  996. ) ENGINE = InnoDB DEFAULT CHARSET = utf8;
  997. TRUNCATE table bi_host_stat;
  998. INSERT INTO bi_host_stat
  999. select
  1000. 'HOUR' as dtype,
  1001. a.thedvalue,
  1002. a.COMPANY,
  1003. case b.mm when 1 then 'CPU' when 2 then '内存' when 3 then '硬盘'when 4 then 'CPU' when 5 then '内存' when 6 then '硬盘'when 7 then 'CPU' when 8 then '内存' when 9 then '硬盘' when 10 then 'CPU' when 11 then '内存' when 12 then '硬盘' else '' end as target,
  1004. case b.mm when 1 then '额定量' when 2 then '额定量' when 3 then '额定量' when 4 then '分配量'
  1005. when 5 then '分配量' when 6 then '分配量'when 7 then '剩余可用' when 8 then '剩余可用' when 9 then '剩余可用' when 10 then '分配占比' when 11 then '分配占比' when 12 then '分配占比' else '' end as dim,
  1006. round(case b.mm when 1 then dim1 when 2 then dim2 when 3 then dim3 when 4 then dim4 when 5 then dim5 when 6 then dim6 when 7 then dim7 when 8 then dim8 when 9 then dim9 when 10 then IF(dim1<>0,dim4/dim1,0) when 11
  1007. then IF(dim2<>0,dim5/dim2,0) when 12 then IF(dim3<>0,dim6/dim3,0) else null end ,2) as dim_value,
  1008. case b.mm when 1 then 'avg' when 2 then 'max' when 3 then 'max'when 4 then 'avg' when 5 then 'max' when 6 then 'max'when 7 then 'avg' when 8 then 'max' when 9 then 'max' else 'avg' end as group_agg,
  1009. case b.mm when 1 then 'GB' when 2 then 'GB' when 3 then 'GB' when 4 then 'GB'
  1010. when 5 then 'GB' when 6 then 'GB'when 7 then 'GB' when 8 then 'GB' when 9 then 'GB' when 10 then '%' when 11 then '%' when 12 then '%' else '' end as unit,
  1011. cloud from (
  1012. SELECT
  1013. date_format( temp1.CREATE_TIME, '%Y%m%d%H' ) AS thedvalue,
  1014. CASE
  1015. temp1.COMPANY
  1016. WHEN 'huawei' THEN
  1017. '太极云资源池'
  1018. WHEN 'huawei-xc' THEN
  1019. '信创云资源池'
  1020. WHEN 'shouxin' THEN
  1021. '首信云资源池'
  1022. WHEN 'unicom' THEN
  1023. '联通云资源池' ELSE '其它'
  1024. END AS COMPANY,
  1025. avg( IND_VALUE_HOST_CPU_UTILIZATION ) AS dim1,
  1026. MAX( IND_VALUE_HOST_MEMORY_TOTAL ) AS dim2,
  1027. MAX( IND_VALUE_HOST_DISK_TOTAL ) AS dim3,
  1028. avg( IND_VALUE_HOST_CPU_TOP ) AS dim4,
  1029. MAX( IND_VALUE_HOST_MEMORY_USED ) AS dim5,
  1030. MAX( IND_VALUE_HOST_DISK_USED ) AS dim6,
  1031. avg( IND_VALUE_HOST_CPU_UTILIZATION_LOW ) AS dim7,
  1032. MAX( IND_VALUE_HOST_MEMORY_UNUSED ) AS dim8,
  1033. MAX( IND_VALUE_HOST_DISK_UNUSED ) AS dim9,
  1034. temp2.cloud
  1035. FROM
  1036. app_host_stat temp1
  1037. LEFT JOIN itm_hardware_resources AS temp2 ON temp1.int_id = temp2.ITM_HARDWARE_RESOURCES_ID
  1038. WHERE
  1039. temp1.COMPANY IS NOT NULL
  1040. GROUP BY
  1041. temp1.COMPANY,
  1042. date_format( temp1.CREATE_TIME, '%Y%m%d%H' ),
  1043. temp2.cloud
  1044. ) a
  1045. cross join
  1046. (select 1 mm
  1047. union all select 2
  1048. union all select 3
  1049. union all select 4
  1050. union all select 5
  1051. union all select 6
  1052. union all select 7
  1053. union all select 8
  1054. union all select 9
  1055. union all select 10
  1056. union all select 11
  1057. union all select 12) b;
  1058. INSERT INTO bi_host_stat
  1059. select 'DAY' as dtype,substring(thedvalue,1,8) AS thedvalue,COMPANY,target,dim,AVG(dim_value),group_agg,unit,cloud
  1060. from bi_host_stat
  1061. where group_agg = 'avg' AND dtype = 'HOUR'
  1062. GROUP BY substring(thedvalue,1,8),COMPANY,target,dim,group_agg,unit,cloud
  1063. UNION ALL
  1064. select 'DAY' as dtype,substring(thedvalue,1,8) AS thedvalue,COMPANY,target,dim,MAX(dim_value),group_agg,unit,cloud
  1065. from bi_host_stat
  1066. where group_agg = 'MAX' AND dtype = 'HOUR'
  1067. GROUP BY substring(thedvalue,1,8),COMPANY,target,dim,group_agg,unit,cloud ;
  1068. INSERT INTO bi_host_stat
  1069. select 'MONTH' as dtype,substring(thedvalue,1,6) AS thedvalue,COMPANY,target,dim,AVG(dim_value),group_agg,unit,cloud
  1070. from bi_host_stat
  1071. where group_agg = 'avg' AND dtype = 'DAY'
  1072. GROUP BY substring(thedvalue,1,6),COMPANY,target,dim,group_agg,unit,cloud
  1073. UNION ALL
  1074. select 'MONTH' as dtype,substring(thedvalue,1,6) AS thedvalue,COMPANY,target,dim,MAX(dim_value),group_agg,unit,cloud
  1075. from bi_host_stat
  1076. where group_agg = 'MAX' AND dtype = 'DAY'
  1077. GROUP BY substring(thedvalue,1,6),COMPANY,target,dim,group_agg,unit,cloud;
  1078. INSERT INTO bi_host_stat
  1079. select 'YEAR' as dtype,substring(thedvalue,1,4) AS thedvalue,COMPANY,target,dim,AVG(dim_value),group_agg,unit,cloud
  1080. from bi_host_stat
  1081. where group_agg = 'avg' AND dtype = 'MONTH'
  1082. GROUP BY substring(thedvalue,1,4),COMPANY,target,dim,group_agg,unit,cloud
  1083. UNION ALL
  1084. select 'YEAR' as dtype,substring(thedvalue,1,4) AS thedvalue,COMPANY,target,dim,MAX(dim_value),group_agg,unit,cloud
  1085. from bi_host_stat
  1086. where group_agg = 'MAX' AND dtype = 'MONTH'
  1087. GROUP BY substring(thedvalue,1,4),COMPANY,target,dim,group_agg,unit,cloud;
  1088. -- (7)设备回收趋势
  1089. -- 建表语句
  1090. DROP TABLE IF EXISTS `bi_recycle_trend`;
  1091. CREATE TABLE `bi_recycle_trend` (
  1092. `dtype` varchar(5) NOT NULL DEFAULT '' COMMENT '日期类型',
  1093. `thedvalue` varchar(15) DEFAULT NULL COMMENT '日期',
  1094. `itm_hardware_resources_cntype` varchar(15) DEFAULT NULL COMMENT '设备类型',
  1095. `NET_NAME` varchar(50) DEFAULT NULL COMMENT '网系',
  1096. `total` decimal(38,4) DEFAULT NULL COMMENT '设备回收数',
  1097. `total_recycled` decimal(38,4) DEFAULT NULL COMMENT '已回收数',
  1098. `total_no_recycled` decimal(38,4) DEFAULT NULL COMMENT '未回收数'
  1099. ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
  1100. -- https://blog.csdn.net/helloxiaozhe/article/details/78570016
  1101. set sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION';
  1102. TRUNCATE table bi_recycle_trend;
  1103. insert into bi_recycle_trend
  1104. SELECT
  1105. 'HOUR' as dtype,
  1106. date_format(a.start_time,'%Y%m%d%H') as thedvalue,
  1107. c.itm_hardware_resources_cntype,
  1108. c.NET_NAME,
  1109. count(1) as total,
  1110. sum(case when a.end_time is not null then 1 else 0 end) as total_recycled,
  1111. sum(case when a.end_time is null then 1 else 0 end) as total_no_recycled
  1112. from icm_bpm.t_work_flow a
  1113. LEFT JOIN icm_bpm.t_work_resource_real b on a.id = b.work_id
  1114. -- LEFT JOIN v_bi_itm_hardware_resources c on c.itm_hardware_resources_id=b.resource_id
  1115. left join (select itm_hardware_resources_ip,itm_hardware_resources_cntype,NET_NAME from (
  1116. select itm_hardware_resources_ip,itm_hardware_resources_cntype,NET_NAME from bi_itm_hardware_resources) a
  1117. group by itm_hardware_resources_ip) c on c.itm_hardware_resources_ip = b.object_id
  1118. WHERE a.process_type_name='基础设施退网'
  1119. GROUP BY date_format(a.start_time,'%Y%m%d%H') ,c.itm_hardware_resources_cntype,c.NET_NAME;
  1120. insert into bi_recycle_trend
  1121. select
  1122. 'DAY' as dtype,
  1123. substr(thedvalue,1,8) as thedvalue,
  1124. itm_hardware_resources_cntype,
  1125. NET_NAME,
  1126. sum(total) as total,
  1127. sum(total_recycled) as total_recycled,
  1128. sum(total_no_recycled) as total_no_recycled
  1129. from bi_recycle_trend
  1130. where dtype = 'HOUR'
  1131. GROUP BY substr(thedvalue,1,8),itm_hardware_resources_cntype,
  1132. NET_NAME;
  1133. insert into bi_recycle_trend
  1134. select
  1135. 'MONTH' as dtype,
  1136. substr(thedvalue,1,6) as thedvalue,
  1137. itm_hardware_resources_cntype,
  1138. NET_NAME,
  1139. sum(total) as total,
  1140. sum(total_recycled) as total_recycled,
  1141. sum(total_no_recycled) as total_no_recycled
  1142. from bi_recycle_trend
  1143. where dtype = 'DAY'
  1144. GROUP BY substr(thedvalue,1,6),itm_hardware_resources_cntype,
  1145. NET_NAME;
  1146. insert into bi_recycle_trend
  1147. select
  1148. 'YEAR' as dtype,
  1149. substr(thedvalue,1,4) as thedvalue,
  1150. itm_hardware_resources_cntype,
  1151. NET_NAME,
  1152. sum(total) as total,
  1153. sum(total_recycled) as total_recycled,
  1154. sum(total_no_recycled) as total_no_recycled
  1155. from bi_recycle_trend
  1156. where dtype = 'MONTH'
  1157. GROUP BY substr(thedvalue,1,4),itm_hardware_resources_cntype,
  1158. NET_NAME;
  1159. -- (8)应用系统监控覆盖率趋势
  1160. -- 建表语句
  1161. DROP TABLE IF EXISTS bi_app_fugai;
  1162. CREATE TABLE `bi_app_fugai` (
  1163. `dtype` varchar(5) NOT NULL DEFAULT '' COMMENT '日期类型',
  1164. `thedvalue` varchar(15) DEFAULT NULL COMMENT '日期',
  1165. `ITM_APP_ID` varchar(255) NOT NULL,
  1166. `ITM_APP_CODE` varchar(45) DEFAULT NULL COMMENT '编码',
  1167. `ITM_APP_NAME` varchar(200) DEFAULT NULL COMMENT '应用名称',
  1168. `ITM_APP_SHORTNAME` varchar(100) DEFAULT NULL COMMENT '应用简称',
  1169. `ITM_APP_DESC` text COMMENT '系统简介',
  1170. `ITM_APP_DEPT` varchar(300) DEFAULT NULL COMMENT '归口部门',
  1171. `ITM_APP_COURTCODE` varchar(45) DEFAULT NULL COMMENT '承建单位\n例如:最高法、山东省高法\n取法院系统的组织机构编码',
  1172. `ITM_NETGROUP_ID` varchar(30) DEFAULT NULL COMMENT '应用所属网系\n更新字典表\nNG000:外部专网\nNG001:法院专网\nNG002:互联网\nNG003:移动专网\nNG004:涉密内网',
  1173. `ITM_APPCATAGORY_ID` varchar(45) DEFAULT NULL,
  1174. `ITM_APP_VENDOR` varchar(45) DEFAULT NULL COMMENT '供应商:浪潮、太极等',
  1175. `ITM_APP_UPTIME` datetime DEFAULT NULL COMMENT '上线时间',
  1176. `ITM_APP_VERSION` varchar(45) DEFAULT NULL,
  1177. `ITM_APP_MAINTENANCE_ID` varchar(45) DEFAULT NULL COMMENT '运维团队,关联运维表,使用内码连接\n',
  1178. `ITM_APP_ORDER` int(45) DEFAULT NULL COMMENT '应用顺序,展示',
  1179. `ITM_APP_NETID` varchar(45) DEFAULT NULL COMMENT '专网编号',
  1180. `ITM_APP_ICONSRC` varchar(100) DEFAULT NULL COMMENT '应用分类\n三类和25类字典表表现',
  1181. `ITM_APP_SYSTEMURL` varchar(300) DEFAULT NULL,
  1182. `ORGAN_ID` varchar(30) DEFAULT NULL COMMENT '机构id,关联机构表',
  1183. `IS_GLOBAL` varchar(45) DEFAULT NULL COMMENT '是否是全局\n如果是全局,则拓扑图是全局的\n如果是非全局,需要维护各自的',
  1184. `ITM_APP_PID` varchar(45) DEFAULT NULL COMMENT '父类系统\n',
  1185. `PLATFORM` varchar(100) DEFAULT NULL COMMENT '七大平台',
  1186. `PRIORITY` varchar(10) DEFAULT NULL COMMENT '优先级:核心-high;重要-important;一般-low',
  1187. `ITM_APP_IP` varchar(30) DEFAULT NULL COMMENT '应用所在服务器IP',
  1188. `ITM_APP_PORT` varchar(10) DEFAULT NULL COMMENT '应用所在服务器端口',
  1189. `ITM_APP_WEBROOT` varchar(100) DEFAULT NULL COMMENT '应用访问路径根目录',
  1190. `ITM_LOCATION` varchar(100) DEFAULT NULL COMMENT '位置信息',
  1191. `ITM_APP_ASSURE_LEVEL` varchar(1) DEFAULT NULL COMMENT '应用保障级别1一级保障',
  1192. `SHOW_TYPE` varchar(10) DEFAULT NULL,
  1193. `ITM_SHOW_FLAG` varchar(10) DEFAULT NULL,
  1194. `int_id` int(22) DEFAULT NULL COMMENT '其他系统关联用ID',
  1195. `INSERT_TIME` timestamp NULL DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP COMMENT '记录插入时间',
  1196. `mantance_vendor` varchar(64) DEFAULT NULL,
  1197. `mantance_duty` varchar(64) DEFAULT NULL,
  1198. `mantance_duty_phone` varchar(128) DEFAULT NULL,
  1199. `start_date` datetime DEFAULT NULL,
  1200. `mantance_year_number` int(16) DEFAULT NULL,
  1201. `ne_type` varchar(64) DEFAULT NULL,
  1202. `creator` varchar(64) DEFAULT NULL,
  1203. `create_time` datetime DEFAULT NULL,
  1204. `modifier` varchar(64) DEFAULT NULL,
  1205. `modify_time` datetime DEFAULT NULL,
  1206. `time_stamp` datetime DEFAULT NULL,
  1207. `stateflag` mediumtext,
  1208. `ruuid` varchar(128) NOT NULL,
  1209. `dataType` varchar(50) DEFAULT NULL,
  1210. `login_action` text,
  1211. `localize_flag` varchar(32) DEFAULT NULL COMMENT '是否国产化,1为国产化,0为非国产化',
  1212. `current_stat` varchar(32) DEFAULT NULL,
  1213. `contract` varchar(64) DEFAULT NULL,
  1214. `emergency_flag` varchar(32) DEFAULT NULL,
  1215. `monitor_flag` varchar(32) DEFAULT NULL,
  1216. `development_language` varchar(32) DEFAULT NULL,
  1217. `app_type` varchar(64) DEFAULT NULL,
  1218. `contract_money` varchar(32) DEFAULT NULL,
  1219. `unified_login` varchar(12) DEFAULT NULL COMMENT '统一登录:0:以接入统一桌面;1:未接入统一桌面',
  1220. `stateflag1` varchar(20) DEFAULT NULL COMMENT '应用状态',
  1221. `PRIORITY1` varchar(20) DEFAULT NULL COMMENT '重要程度',
  1222. `app_type_name` varchar(20) DEFAULT NULL COMMENT '分类',
  1223. `net_name` varchar(20) DEFAULT NULL COMMENT '网系',
  1224. `cloud_flag` varchar(20) DEFAULT NULL COMMENT '应用对应资源是否上云1为上云,0为不上云',
  1225. `organ_name` varchar(200) DEFAULT NULL COMMENT '区域',
  1226. `itm_hardware_resources_areacode` varchar(100) DEFAULT NULL COMMENT '设备区域',
  1227. `on_line` varchar(255) DEFAULT NULL,
  1228. `cloud` varchar(255) DEFAULT NULL COMMENT '云平台'
  1229. ) ENGINE = InnoDB DEFAULT CHARSET = utf8;
  1230. TRUNCATE table bi_app_fugai;
  1231. insert into bi_app_fugai
  1232. select 'DAY' AS dtype, a.thedvalue, b.ITM_APP_ID ,b.ITM_APP_CODE ,b.ITM_APP_NAME ,b.ITM_APP_SHORTNAME ,b.ITM_APP_DESC ,b.ITM_APP_DEPT ,b.ITM_APP_COURTCODE ,
  1233. b.ITM_NETGROUP_ID ,b.ITM_APPCATAGORY_ID ,b.ITM_APP_VENDOR ,b.ITM_APP_UPTIME ,b.ITM_APP_VERSION ,b.ITM_APP_MAINTENANCE_ID ,b.ITM_APP_ORDER ,b.ITM_APP_NETID ,
  1234. b.ITM_APP_ICONSRC ,b.ITM_APP_SYSTEMURL ,b.ORGAN_ID ,b.IS_GLOBAL ,b.ITM_APP_PID ,b.PLATFORM ,b.PRIORITY ,b.ITM_APP_IP ,b.ITM_APP_PORT ,b.ITM_APP_WEBROOT ,
  1235. b.ITM_LOCATION ,b.ITM_APP_ASSURE_LEVEL ,b.SHOW_TYPE ,b.ITM_SHOW_FLAG ,b.int_id ,b.INSERT_TIME ,b.mantance_vendor ,b.mantance_duty ,b.mantance_duty_phone ,
  1236. b.start_date ,b.mantance_year_number ,b.ne_type ,b.creator ,b.create_time ,b.modifier ,b.modify_time ,b.time_stamp ,b.stateflag ,b.ruuid ,b.data_Type ,b.login_action ,
  1237. b.localize_flag ,b.current_stat ,b.contract ,b.emergency_flag ,b.monitor_flag ,b.development_language ,b.app_type ,b.contract_money ,b.unified_login,
  1238. case b.stateflag when 0 then '已应用' else '未应用' end as stateflag1,
  1239. case b.PRIORITY WHEN 'low' then '一般应用' when 'important' then '重要应用' when 'high' then '核心应用' else '未知' end as PRIORITY1,
  1240. c.name as app_type_name,
  1241. d.net_name as net_name,
  1242. e.cloud_flag as cloud_flag,
  1243. f.`SHORT_NAME` as organ_name,
  1244. e.itm_hardware_resources_areacode as itm_hardware_resources_areacode,
  1245. b.on_line as on_line,
  1246. e.cloud
  1247. from (
  1248. select distinct date_format(dt_d,'%Y%m%d') as thedvalue from bi_m_date where dt_d >= '2021-01-01' and dt_d < '2023-11-09') a
  1249. left join itm_app b
  1250. on a.thedvalue >= date_format(b.create_time,'%Y%m%d')
  1251. LEFT JOIN m_com_dict c on b.app_type=c.value
  1252. LEFT JOIN itm_organ_net d on d.NET_ID = b.ITM_NETGROUP_ID
  1253. -- 只要app的一个资源上云了 就说明上云了
  1254. LEFT JOIN (SELECT servicename,itm_hardware_resources_areacode,concat(max(CASE WHEN itm_hardware_resources_cntype = '云主机' then 1 else 0 end),'') as cloud_flag,cloud
  1255. from bi_itm_hardware_resources where servicename is not null and servicename != '' group by servicename,itm_hardware_resources_areacode,cloud) e
  1256. on b.ITM_APP_NAME= e.servicename
  1257. left join pub_organ f
  1258. on b.ORGAN_ID = f.`CODE`
  1259. WHERE c.dict_index='app_type'
  1260. UNION ALL
  1261. select 'MONTH' AS dtype, a.thedvalue, b.ITM_APP_ID ,b.ITM_APP_CODE ,b.ITM_APP_NAME ,b.ITM_APP_SHORTNAME ,b.ITM_APP_DESC ,b.ITM_APP_DEPT ,b.ITM_APP_COURTCODE ,
  1262. b.ITM_NETGROUP_ID ,b.ITM_APPCATAGORY_ID ,b.ITM_APP_VENDOR ,b.ITM_APP_UPTIME ,b.ITM_APP_VERSION ,b.ITM_APP_MAINTENANCE_ID ,b.ITM_APP_ORDER ,b.ITM_APP_NETID ,
  1263. b.ITM_APP_ICONSRC ,b.ITM_APP_SYSTEMURL ,b.ORGAN_ID ,b.IS_GLOBAL ,b.ITM_APP_PID ,b.PLATFORM ,b.PRIORITY ,b.ITM_APP_IP ,b.ITM_APP_PORT ,b.ITM_APP_WEBROOT ,
  1264. b.ITM_LOCATION ,b.ITM_APP_ASSURE_LEVEL ,b.SHOW_TYPE ,b.ITM_SHOW_FLAG ,b.int_id ,b.INSERT_TIME ,b.mantance_vendor ,b.mantance_duty ,b.mantance_duty_phone ,
  1265. b.start_date ,b.mantance_year_number ,b.ne_type ,b.creator ,b.create_time ,b.modifier ,b.modify_time ,b.time_stamp ,b.stateflag ,b.ruuid ,b.data_Type ,b.login_action ,
  1266. b.localize_flag ,b.current_stat ,b.contract ,b.emergency_flag ,b.monitor_flag ,b.development_language ,b.app_type ,b.contract_money ,b.unified_login,
  1267. case b.stateflag when 0 then '已应用' else '未应用' end as stateflag1,
  1268. case b.PRIORITY WHEN 'low' then '一般应用' when 'important' then '重要应用' when 'high' then '核心应用' else '未知' end as PRIORITY1,
  1269. c.name as app_type_name,
  1270. d.net_name as net_name,
  1271. e.cloud_flag as cloud_flag,
  1272. f.`SHORT_NAME` as organ_name,
  1273. e.itm_hardware_resources_areacode as itm_hardware_resources_areacode,
  1274. b.on_line as on_line,
  1275. e.cloud
  1276. from (
  1277. select distinct date_format(dt_d,'%Y%m') as thedvalue from bi_m_date where dt_d >= '2021-01-01' and dt_d < '2023-11-09') a
  1278. left join itm_app b
  1279. on a.thedvalue >= date_format(b.create_time,'%Y%m')
  1280. LEFT JOIN m_com_dict c on b.app_type=c.value
  1281. LEFT JOIN itm_organ_net d on d.NET_ID = b.ITM_NETGROUP_ID
  1282. -- 只要app的一个资源上云了 就说明上云了
  1283. LEFT JOIN (SELECT servicename,itm_hardware_resources_areacode,concat(max(CASE WHEN itm_hardware_resources_cntype = '云主机' then 1 else 0 end),'') as cloud_flag,cloud
  1284. from bi_itm_hardware_resources where servicename is not null and servicename != '' group by servicename,itm_hardware_resources_areacode,cloud) e
  1285. on b.ITM_APP_NAME= e.servicename
  1286. left join pub_organ f
  1287. on b.ORGAN_ID = f.`CODE`
  1288. WHERE c.dict_index='app_type'
  1289. UNION ALL
  1290. select 'YEAR' AS dtype, a.thedvalue, b.ITM_APP_ID ,b.ITM_APP_CODE ,b.ITM_APP_NAME ,b.ITM_APP_SHORTNAME ,b.ITM_APP_DESC ,b.ITM_APP_DEPT ,b.ITM_APP_COURTCODE ,
  1291. b.ITM_NETGROUP_ID ,b.ITM_APPCATAGORY_ID ,b.ITM_APP_VENDOR ,b.ITM_APP_UPTIME ,b.ITM_APP_VERSION ,b.ITM_APP_MAINTENANCE_ID ,b.ITM_APP_ORDER ,b.ITM_APP_NETID ,
  1292. b.ITM_APP_ICONSRC ,b.ITM_APP_SYSTEMURL ,b.ORGAN_ID ,b.IS_GLOBAL ,b.ITM_APP_PID ,b.PLATFORM ,b.PRIORITY ,b.ITM_APP_IP ,b.ITM_APP_PORT ,b.ITM_APP_WEBROOT ,
  1293. b.ITM_LOCATION ,b.ITM_APP_ASSURE_LEVEL ,b.SHOW_TYPE ,b.ITM_SHOW_FLAG ,b.int_id ,b.INSERT_TIME ,b.mantance_vendor ,b.mantance_duty ,b.mantance_duty_phone ,
  1294. b.start_date ,b.mantance_year_number ,b.ne_type ,b.creator ,b.create_time ,b.modifier ,b.modify_time ,b.time_stamp ,b.stateflag ,b.ruuid ,b.data_Type ,b.login_action ,
  1295. b.localize_flag ,b.current_stat ,b.contract ,b.emergency_flag ,b.monitor_flag ,b.development_language ,b.app_type ,b.contract_money ,b.unified_login,
  1296. case b.stateflag when 0 then '已应用' else '未应用' end as stateflag1,
  1297. case b.PRIORITY WHEN 'low' then '一般应用' when 'important' then '重要应用' when 'high' then '核心应用' else '未知' end as PRIORITY1,
  1298. c.name as app_type_name,
  1299. d.net_name as net_name,
  1300. e.cloud_flag as cloud_flag,
  1301. f.`SHORT_NAME` as organ_name,
  1302. e.itm_hardware_resources_areacode as itm_hardware_resources_areacode,
  1303. b.on_line as on_line,
  1304. e.cloud
  1305. from (
  1306. select distinct date_format(dt_d,'%Y') as thedvalue from bi_m_date where dt_d >= '2021-01-01' and dt_d < '2023-11-09') a
  1307. left join itm_app b
  1308. on a.thedvalue >= date_format(b.create_time,'%Y')
  1309. LEFT JOIN m_com_dict c on b.app_type=c.value
  1310. LEFT JOIN itm_organ_net d on d.NET_ID = b.ITM_NETGROUP_ID
  1311. -- 只要app的一个资源上云了 就说明上云了
  1312. LEFT JOIN (SELECT servicename,itm_hardware_resources_areacode,concat(max(CASE WHEN itm_hardware_resources_cntype = '云主机' then 1 else 0 end),'') as cloud_flag, cloud
  1313. from bi_itm_hardware_resources where servicename is not null and servicename != '' group by servicename,itm_hardware_resources_areacode,cloud) e
  1314. on b.ITM_APP_NAME= e.servicename
  1315. left join pub_organ f
  1316. on b.ORGAN_ID = f.`CODE`
  1317. WHERE c.dict_index='app_type';
  1318. -- (9)基础设施上线趋势
  1319. -- 建表语句
  1320. DROP TABLE IF EXISTS `bi_online_trend`;
  1321. CREATE TABLE `bi_online_trend` (
  1322. `dtype` varchar(5) NOT NULL DEFAULT '' COMMENT '日期类型',
  1323. `thedvalue` varchar(15) DEFAULT NULL COMMENT '日期',
  1324. `itm_hardware_resources_areacode` varchar(100) DEFAULT NULL COMMENT '区域/机房',
  1325. `itm_hardware_resources_cntype` varchar(15) DEFAULT NULL COMMENT '设备类型',
  1326. `itm_hardware_resources_name` varchar(100) DEFAULT NULL COMMENT '设备名称',
  1327. `NET_NAME` varchar(50) DEFAULT NULL COMMENT '网系',
  1328. `total` decimal(38,4) DEFAULT NULL COMMENT '上线总量',
  1329. `ended_total` decimal(38, 4) DEFAULT NULL COMMENT '退网总量',
  1330. `ending_total` decimal(38, 4) DEFAULT NULL COMMENT '退网中总量'
  1331. ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
  1332. set sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION';
  1333. truncate table bi_online_trend;
  1334. insert into bi_online_trend
  1335. SELECT
  1336. 'HOUR' as dtype,
  1337. date_format(a.end_time,'%Y%m%d%H') as thedvalue,
  1338. c.itm_hardware_resources_areacode,
  1339. c.itm_hardware_resources_cntype,
  1340. c.itm_hardware_resources_name,
  1341. c.NET_NAME,
  1342. SUM(CASE WHEN a.process_type_name='基础设施入网' and a.end_time is not null THEN 1 ELSE 0 END) as 'total',
  1343. SUM(CASE WHEN a.process_type_name='基础设施退网' and a.end_time is not null THEN 1 ELSE 0 END) as 'ended_total',
  1344. SUM(CASE WHEN a.process_type_name='基础设施退网' and a.end_time is null THEN 1 ELSE 0 END) as 'ending_total'
  1345. from icm_bpm.t_work_flow a
  1346. LEFT JOIN icm_bpm.t_work_resource_real b on a.id = b.work_id
  1347. left join (
  1348. select itm_hardware_resources_id,itm_hardware_resources_cntype,NET_NAME,itm_hardware_resources_areacode,itm_hardware_resources_name from (
  1349. select itm_hardware_resources_id,itm_hardware_resources_cntype,NET_NAME,itm_hardware_resources_areacode, itm_hardware_resources_name from bi_itm_hardware_resources) a
  1350. group by itm_hardware_resources_id
  1351. ) c on c.itm_hardware_resources_id = b.object_id
  1352. GROUP BY date_format(a.end_time,'%Y%m%d%H'),c.itm_hardware_resources_areacode,c.itm_hardware_resources_cntype,c.NET_NAME;
  1353. insert into bi_online_trend
  1354. select
  1355. 'DAY' as dtype,
  1356. substr(thedvalue,1,8) as thedvalue,
  1357. itm_hardware_resources_areacode,
  1358. itm_hardware_resources_cntype,
  1359. itm_hardware_resources_name,
  1360. NET_NAME,
  1361. sum(total) as total,
  1362. sum(ended_total) as ended_total,
  1363. sum(ending_total) as ending_total
  1364. from bi_online_trend
  1365. where dtype = 'HOUR'
  1366. GROUP BY substr(thedvalue,1,8),itm_hardware_resources_areacode,itm_hardware_resources_cntype,NET_NAME;
  1367. insert into bi_online_trend
  1368. select
  1369. 'MONTH' as dtype,
  1370. substr(thedvalue,1,6) as thedvalue,
  1371. itm_hardware_resources_areacode,
  1372. itm_hardware_resources_cntype,
  1373. itm_hardware_resources_name,
  1374. NET_NAME,
  1375. sum(total) as total,
  1376. sum(ended_total) as ended_total,
  1377. sum(ending_total) as ending_total
  1378. from bi_online_trend
  1379. where dtype = 'DAY'
  1380. GROUP BY substr(thedvalue,1,6),itm_hardware_resources_areacode,itm_hardware_resources_cntype,NET_NAME;
  1381. insert into bi_online_trend
  1382. select
  1383. 'YEAR' as dtype,
  1384. substr(thedvalue,1,4) as thedvalue,
  1385. itm_hardware_resources_areacode,
  1386. itm_hardware_resources_cntype,
  1387. itm_hardware_resources_name,
  1388. NET_NAME,
  1389. sum(total) as total,
  1390. sum(ended_total) as ended_total,
  1391. sum(ending_total) as ending_total
  1392. from bi_online_trend
  1393. where dtype = 'MONTH'
  1394. GROUP BY substr(thedvalue,1,4),itm_hardware_resources_areacode,itm_hardware_resources_cntype,NET_NAME;
  1395. -- (10)操作次数趋势、响应时间趋势、应用系统用户趋势
  1396. -- 建表语句
  1397. DROP TABLE IF EXISTS `bi_app_log_result`;
  1398. CREATE TABLE `bi_app_log_result` (
  1399. `dtype` varchar(5) NOT NULL DEFAULT '' COMMENT '日期类型',
  1400. `thedvalue` varchar(15) DEFAULT NULL COMMENT '日期',
  1401. `dhour` varchar(15) DEFAULT NULL COMMENT '小时',
  1402. `PRIORITY` varchar(20) DEFAULT NULL COMMENT '重要程度',
  1403. `app_type_name` varchar(50) DEFAULT NULL COMMENT '分类',
  1404. `net_name` varchar(50) DEFAULT NULL COMMENT '网系',
  1405. `id` bigint(20) NOT NULL DEFAULT '0' COMMENT '自增标记,用于数据同步',
  1406. `app_id` varchar(200) DEFAULT NULL COMMENT '应用ID',
  1407. `app_name` varchar(200) DEFAULT NULL COMMENT '应用名称',
  1408. `orgin_id` varchar(32) DEFAULT NULL COMMENT '组织ID',
  1409. `net_id` varchar(30) DEFAULT NULL,
  1410. `independent_visits_num` varchar(10) DEFAULT NULL COMMENT '独立访客数/活跃用户数',
  1411. `visits_num` varchar(10) DEFAULT NULL COMMENT '访客数',
  1412. `oper_num` varchar(10) DEFAULT NULL COMMENT '操作次数/访问量',
  1413. `slow_oper` varchar(10) DEFAULT NULL COMMENT '慢操作占比',
  1414. `min_resp_time` varchar(10) DEFAULT NULL COMMENT '最小响应时间(毫秒)',
  1415. `max_resp_time` varchar(10) DEFAULT NULL COMMENT '最大响应时间(毫秒)',
  1416. `avg_resp_time` varchar(10) DEFAULT NULL COMMENT '平均响应时间(毫秒)',
  1417. `time_stamp` varchar(32) DEFAULT NULL COMMENT '时间戳',
  1418. `monitor_time` varchar(32) DEFAULT NULL COMMENT '推送时间',
  1419. `territory_visitor` varchar(32) DEFAULT NULL COMMENT '地域访问数',
  1420. `reg_user_num` varchar(32) DEFAULT NULL COMMENT '注册用户数',
  1421. `sign_num` varbinary(32) DEFAULT NULL COMMENT '登录次数',
  1422. `new_reg_user_num` varchar(32) DEFAULT NULL COMMENT '新注册用户数',
  1423. `time_type` varchar(32) DEFAULT NULL COMMENT '类型(hour:小时 day:天 month:月 国内:domestic 国外:foreign)',
  1424. `create_time` varchar(32) DEFAULT NULL COMMENT '插入时间',
  1425. `organ_name` varchar(200) DEFAULT NULL COMMENT '区域'
  1426. ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
  1427. truncate table bi_app_log_result;
  1428. insert into bi_app_log_result
  1429. select
  1430. 'HOUR' as dtype,
  1431. date_format(a.monitor_time,'%Y%m%d%H') as thedvalue,
  1432. date_format(a.monitor_time,'%H') as dhour,
  1433. case b.PRIORITY WHEN 'low' then '一般应用' when 'important' then '重要应用' when 'high' then '核心应用' else '未知' end as PRIORITY,
  1434. d.name as app_type_name,
  1435. c.net_name as net_name,
  1436. a.id ,a.app_id ,a.app_name ,a.orgin_id ,a.net_id,sum(a.independent_visits_num) as independent_visits_num,sum(a.visits_num) as visits_num,
  1437. sum(a.oper_num) as oper_num,avg(a.slow_oper + 0.0) as slow_oper,min(a.min_resp_time) as min_resp_time,max(max_resp_time) as max_resp_time,
  1438. avg(a.avg_resp_time + 0.0) as avg_resp_time,date_format(a.monitor_time,'%H') as time_stamp,'' as monitor_time,
  1439. sum(a.territory_visitor) as territory_visitor,sum(a.reg_user_num) as reg_user_num,'' as sign_num,sum(a.new_reg_user_num) as new_reg_user_num,
  1440. '' as time_type,'' as create_time,
  1441. e.`SHORT_NAME` as organ_name
  1442. from t_ind_obj_app_log_result a
  1443. LEFT JOIN itm_app b on a.app_id =b.ITM_APP_ID
  1444. LEFT JOIN itm_organ_net c on c.NET_ID = a.net_id
  1445. inner JOIN (select * from m_com_dict where dict_index = 'app_type') d on b.app_type=d.value
  1446. left join pub_organ e
  1447. on b.ORGAN_ID = e.`CODE`
  1448. WHERE
  1449. time_type in('hour')
  1450. group by
  1451. date_format(a.monitor_time,'%Y%m%d%H'),date_format(a.monitor_time,'%H'),
  1452. case b.PRIORITY WHEN 'low' then '一般应用' when 'important' then '重要应用' when 'high' then '核心应用' else '未知' end,d.name,c.net_name,a.id ,a.app_id ,a.app_name ,a.orgin_id ,a.net_id,e.`SHORT_NAME`;
  1453. insert into bi_app_log_result
  1454. select
  1455. 'DAY' as dtype,
  1456. substring(thedvalue,1,8) AS thedvalue,
  1457. dhour,PRIORITY,app_type_name,net_name,id ,app_id ,app_name ,orgin_id ,net_id,sum(independent_visits_num) as independent_visits_num,sum(visits_num) as visits_num,
  1458. sum(oper_num) as oper_num,avg(slow_oper + 0.0) as slow_oper,min(min_resp_time) as min_resp_time,max(max_resp_time) as max_resp_time,
  1459. avg(avg_resp_time + 0.0) as avg_resp_time,dhour as time_stamp,'' as monitor_time,
  1460. sum(territory_visitor) as territory_visitor,sum(reg_user_num) as reg_user_num,'' as sign_num,sum(new_reg_user_num) as new_reg_user_num,
  1461. '' as time_type,'' as create_time,organ_name
  1462. from bi_app_log_result
  1463. where dtype = 'HOUR'
  1464. group by substring(thedvalue,1,8),dhour,PRIORITY,app_type_name,net_name,id ,app_id ,app_name ,orgin_id ,net_id,organ_name;
  1465. insert into bi_app_log_result
  1466. select
  1467. 'MONTH' as dtype,
  1468. substring(thedvalue,1,6) AS thedvalue,
  1469. dhour,PRIORITY,app_type_name,net_name,id ,app_id ,app_name ,orgin_id ,net_id,sum(independent_visits_num) as independent_visits_num,sum(visits_num) as visits_num,
  1470. sum(oper_num) as oper_num,avg(slow_oper + 0.0) as slow_oper,min(min_resp_time) as min_resp_time,max(max_resp_time) as max_resp_time,
  1471. avg(avg_resp_time + 0.0) as avg_resp_time,dhour as time_stamp,'' as monitor_time,
  1472. sum(territory_visitor) as territory_visitor,sum(reg_user_num) as reg_user_num,'' as sign_num,sum(new_reg_user_num) as new_reg_user_num,
  1473. '' as time_type,'' as create_time,organ_name
  1474. from bi_app_log_result
  1475. where dtype = 'DAY'
  1476. group by substring(thedvalue,1,6),dhour,PRIORITY,app_type_name,net_name,id ,app_id ,app_name ,orgin_id ,net_id,organ_name;
  1477. insert into bi_app_log_result
  1478. select
  1479. 'YEAR' as dtype,
  1480. substring(thedvalue,1,4) AS thedvalue,
  1481. dhour,PRIORITY,app_type_name,net_name,id ,app_id ,app_name ,orgin_id ,net_id,sum(independent_visits_num) as independent_visits_num,sum(visits_num) as visits_num,
  1482. sum(oper_num) as oper_num,avg(slow_oper + 0.0) as slow_oper,min(min_resp_time) as min_resp_time,max(max_resp_time) as max_resp_time,
  1483. avg(avg_resp_time + 0.0) as avg_resp_time,dhour as time_stamp,'' as monitor_time,
  1484. sum(territory_visitor) as territory_visitor,sum(reg_user_num) as reg_user_num,'' as sign_num,sum(new_reg_user_num) as new_reg_user_num,
  1485. '' as time_type,'' as create_time,organ_name
  1486. from bi_app_log_result
  1487. where dtype = 'MONTH'
  1488. group by substring(thedvalue,1,4),dhour,PRIORITY,app_type_name,net_name,id ,app_id ,app_name ,orgin_id ,net_id,organ_name;
  1489. -- (16)应用漏洞变化趋势
  1490. -- 建表语句
  1491. DROP TABLE IF EXISTS `bi_panoramic_view_app_ld_trend`;
  1492. CREATE TABLE `bi_panoramic_view_app_ld_trend` (
  1493. `dtype` varchar(5) NOT NULL DEFAULT '' COMMENT '日期类型',
  1494. `thedvalue` varchar(8) DEFAULT NULL COMMENT '日期类型',
  1495. `app_name` varchar(128) DEFAULT NULL COMMENT '应用名称',
  1496. `score_count` varchar(53) DEFAULT NULL COMMENT '指标值',
  1497. `NET_NAME` varchar(30) DEFAULT NULL COMMENT '网系名称',
  1498. `score_name` varchar(25) DEFAULT NULL COMMENT '覆盖率,合格率'
  1499. ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
  1500. truncate table bi_panoramic_view_app_ld_trend;
  1501. insert into bi_panoramic_view_app_ld_trend
  1502. select
  1503. 'DAY' as dtype,date_format(savi.insert_time,'%Y%m%d') as thedvalue,
  1504. savi.name as app_name,
  1505. max(savi.vul_total_count) as score_count,
  1506. ion.NET_NAME as NET_NAME,
  1507. mcd.name as score_name
  1508. from safe_app_vul_info savi
  1509. LEFT JOIN itm_app ia on savi.name = ia.ITM_APP_NAME
  1510. LEFT JOIN m_com_dict mcd on ia.app_type = mcd.dispindex and mcd.dict_index='app_type'
  1511. LEFT JOIN itm_organ_net ion on ia.ITM_NETGROUP_ID = ion.NET_ID
  1512. GROUP BY date_format(savi.insert_time,'%Y%m%d'),savi.name,ion.NET_NAME,mcd.name;
  1513. insert into bi_panoramic_view_app_ld_trend
  1514. select
  1515. 'MONTH' as dtype,
  1516. substr(thedvalue,1,6) as thedvalue,
  1517. app_name,
  1518. sum(score_count) as score_count,
  1519. NET_NAME,
  1520. score_name
  1521. from bi_panoramic_view_app_ld_trend
  1522. where dtype = 'DAY'
  1523. GROUP BY substr(thedvalue,1,6),app_name,NET_NAME,score_name;
  1524. insert into bi_panoramic_view_app_ld_trend
  1525. select
  1526. 'YEAR' as dtype,
  1527. substr(thedvalue,1,4) as thedvalue,
  1528. app_name,
  1529. sum(score_count) as score_count,
  1530. NET_NAME,
  1531. score_name
  1532. from bi_panoramic_view_app_ld_trend
  1533. where dtype = 'MONTH'
  1534. GROUP BY substr(thedvalue,1,4),app_name,NET_NAME,score_name;
  1535. -- 建表语句
  1536. DROP TABLE IF EXISTS `bi_panoramic_new_trend`;
  1537. CREATE TABLE `bi_panoramic_new_trend` (
  1538. `dtype` varchar(10) CHARACTER SET utf8mb4 NOT NULL DEFAULT '' COMMENT '日期类型',
  1539. `thedvalue` varchar(20) CHARACTER SET utf8mb4 DEFAULT NULL COMMENT '日期',
  1540. `app_name` varchar(50) DEFAULT NULL COMMENT '设备资产名称',
  1541. `score_name` varchar(50) DEFAULT NULL COMMENT '选择对象',
  1542. `the_score` double DEFAULT NULL COMMENT '网系名称',
  1543. `NET_NAME` varchar(100) DEFAULT NULL COMMENT '网系名称',
  1544. `organ_name` varchar(100) DEFAULT NULL COMMENT '区域'
  1545. ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
  1546. -- 用cross join进行的列转行
  1547. truncate table bi_panoramic_new_trend;
  1548. insert into bi_panoramic_new_trend
  1549. select
  1550. 'DAY' as dtype,
  1551. thedvalue,
  1552. '' as app_name,
  1553. case b.mm when 1 then '安全设备' when 2 then '网络设备' when 3 then '终端PC' when 4 then '服务器' else '' end as score_name,
  1554. case b.mm when 1 then security_device_vul_total_count when 2 then network_device_vul_total_count when 3 then terminal_vul_total_count when 4 then server_vul_total_count else 0.0 end as the_score,
  1555. null as NET_NAME,
  1556. null as organ_name
  1557. from
  1558. (select
  1559. date_format(insert_time,'%Y%m%d') as thedvalue,
  1560. max(security_device_vul_total_count) + 0.0 as security_device_vul_total_count,
  1561. max(network_device_vul_total_count) + 0.0 as network_device_vul_total_count,
  1562. max(terminal_vul_total_count) + 0.0 as terminal_vul_total_count,
  1563. max(server_vul_total_count) + 0.0 as server_vul_total_count
  1564. from safe_index_info_1
  1565. group by date_format(insert_time,'%Y%m%d'),id) a
  1566. cross join
  1567. (select 1 mm
  1568. union all select 2
  1569. union all select 3
  1570. union all select 4) b
  1571. union all
  1572. select
  1573. 'DAY' as dtype,
  1574. date_format(savi.insert_time,'%Y%m%d') as thedvalue,
  1575. savi.name as app_name,
  1576. '应用系统' as score_name,
  1577. max(savi.vul_total_count) as the_score,
  1578. ion.NET_NAME as NET_NAME,
  1579. f.name as organ_name
  1580. from safe_app_vul_info savi
  1581. LEFT JOIN itm_app ia on savi.name = ia.ITM_APP_NAME
  1582. LEFT JOIN m_com_dict mcd on ia.app_type = mcd.dispindex and mcd.dict_index='app_type'
  1583. LEFT JOIN itm_organ_net ion on ia.ITM_NETGROUP_ID = ion.NET_ID
  1584. left join pub_organ f on ia.ORGAN_ID = f.`CODE`
  1585. GROUP BY date_format(savi.insert_time,'%Y%m%d'),savi.name,ion.NET_NAME,f.name;
  1586. insert into bi_panoramic_new_trend
  1587. select 'MONTH' as dtype,substring(thedvalue,1,6) AS thedvalue,
  1588. app_name,score_name,avg(the_score) as the_score,NET_NAME,organ_name
  1589. from bi_panoramic_new_trend
  1590. where dtype = 'DAY'
  1591. GROUP BY substring(thedvalue,1,6),app_name,score_name,NET_NAME,organ_name;
  1592. insert into bi_panoramic_new_trend
  1593. select 'YEAR' as dtype,substring(thedvalue,1,4) AS thedvalue,
  1594. app_name,score_name,avg(the_score) as the_score,NET_NAME,organ_name
  1595. from bi_panoramic_new_trend
  1596. where dtype = 'MONTH'
  1597. GROUP BY substring(thedvalue,1,4),app_name,score_name,NET_NAME,organ_name;
  1598. -- (20)综合安全评分趋势
  1599. -- 建表语句
  1600. DROP TABLE IF EXISTS `bi_panoramic_view_safe_trend`;
  1601. CREATE TABLE `bi_panoramic_view_safe_trend` (
  1602. `dtype` varchar(10) CHARACTER SET utf8mb4 NOT NULL DEFAULT '' COMMENT '日期类型',
  1603. `thedvalue` varchar(20) CHARACTER SET utf8mb4 DEFAULT NULL COMMENT '日期',
  1604. `id` varchar(50) NOT NULL DEFAULT '0' COMMENT '设备名称暂时没有数据',
  1605. `score_name` varchar(50) CHARACTER SET utf8mb4 NOT NULL DEFAULT '' COMMENT '指标名称',
  1606. `the_score` double DEFAULT NULL COMMENT '指标值'
  1607. ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
  1608. truncate table bi_panoramic_view_safe_trend;
  1609. insert into bi_panoramic_view_safe_trend
  1610. select
  1611. 'DAY' as dtype,
  1612. thedvalue,
  1613. '' as id,
  1614. case b.mm when 1 then '综合分' when 2 then '网络资源明晰度评分' when 3 then '资产脆弱性安全指数得分' when 4 then '网络攻击安全指数得分'
  1615. when 5 then '边界安全指数得分' when 6 then '应用系统合规性得分' when 7 then '运维风险可控度得分' else '' end as score_name,
  1616. case b.mm when 1 then global_score when 2 then network_resource_score when 3 then asset_vul_score when 4 then network_security_score
  1617. when 5 then border_security_score when 6 then application_system_score when 7 then operation_risk_score else 0.0 end as the_score
  1618. from
  1619. (select
  1620. date_format(insert_time,'%Y%m%d') as thedvalue,
  1621. max(global_score) + 0.0 as global_score,
  1622. max(network_resource_score) + 0.0 as network_resource_score,
  1623. max(asset_vul_score) + 0.0 as asset_vul_score,
  1624. max(network_security_score) + 0.0 as network_security_score,
  1625. max(border_security_score) + 0.0 as border_security_score,
  1626. max(application_system_score) + 0.0 as application_system_score,
  1627. max(operation_risk_score) + 0.0 as operation_risk_score
  1628. from safe_index_score
  1629. group by date_format(insert_time,'%Y%m%d'),id) a
  1630. cross join
  1631. (select 1 mm
  1632. union all select 2
  1633. union all select 3
  1634. union all select 4
  1635. union all select 5
  1636. union all select 6
  1637. union all select 7) b;
  1638. insert into bi_panoramic_view_safe_trend
  1639. select 'MONTH' as dtype,substring(thedvalue,1,6) AS thedvalue,
  1640. '' as id,score_name,avg(the_score) as the_score
  1641. from bi_panoramic_view_safe_trend
  1642. where dtype = 'DAY'
  1643. GROUP BY substring(thedvalue,1,6),score_name;
  1644. insert into bi_panoramic_view_safe_trend
  1645. select 'YEAR' as dtype,substring(thedvalue,1,4) AS thedvalue,
  1646. '' as id,score_name,avg(the_score) as the_score
  1647. from bi_panoramic_view_safe_trend
  1648. where dtype = 'MONTH'
  1649. GROUP BY substring(thedvalue,1,4),score_name;
  1650. -- (21)网络攻击变化趋势
  1651. -- 建表语句
  1652. DROP TABLE IF EXISTS `bi_panoramic_view_net_attack_trend`;
  1653. CREATE TABLE `bi_panoramic_view_net_attack_trend` (
  1654. `dtype` varchar(10) CHARACTER SET utf8mb4 NOT NULL DEFAULT '' COMMENT '日期类型',
  1655. `thedvalue` varchar(20) CHARACTER SET utf8mb4 DEFAULT NULL COMMENT '日期',
  1656. `score_name` varchar(50) CHARACTER SET utf8mb4 NOT NULL DEFAULT '' COMMENT '指标名称',
  1657. `the_score` double DEFAULT NULL COMMENT '指标值'
  1658. ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
  1659. truncate table bi_panoramic_view_net_attack_trend;
  1660. insert into bi_panoramic_view_net_attack_trend
  1661. select
  1662. 'DAY' as dtype,
  1663. thedvalue,
  1664. case b.mm when 1 then '网络攻击尝试数' when 2 then '网络攻击成功数' when 3 then '网络攻击结果不明数' when 4 then '恶意程序数' else '' end as score_name,
  1665. case b.mm when 1 then network_attack_try_count when 2 then network_attack_success_count when 3 then network_attack_unknown_count when 4 then server_vul_total_count else 0.0 end as the_score
  1666. from
  1667. (select
  1668. date_format(insert_time,'%Y%m%d') as thedvalue,
  1669. max(network_attack_try_count) + 0.0 as network_attack_try_count,
  1670. max(network_attack_success_count) + 0.0 as network_attack_success_count,
  1671. max(network_attack_unknown_count) + 0.0 as network_attack_unknown_count,
  1672. max(server_vul_total_count) + 0.0 as server_vul_total_count
  1673. from safe_index_info_1
  1674. group by date_format(insert_time,'%Y%m%d'),id) a
  1675. cross join
  1676. (select 1 mm
  1677. union all select 2
  1678. union all select 3
  1679. union all select 4) b;
  1680. insert into bi_panoramic_view_net_attack_trend
  1681. select 'MONTH' as dtype,substring(thedvalue,1,6) AS thedvalue,
  1682. score_name,avg(the_score) as the_score
  1683. from bi_panoramic_view_net_attack_trend
  1684. where dtype = 'DAY'
  1685. GROUP BY substring(thedvalue,1,6),score_name;
  1686. insert into bi_panoramic_view_net_attack_trend
  1687. select 'YEAR' as dtype,substring(thedvalue,1,4) AS thedvalue,
  1688. score_name,avg(the_score) as the_score
  1689. from bi_panoramic_view_net_attack_trend
  1690. where dtype = 'MONTH'
  1691. GROUP BY substring(thedvalue,1,4),score_name;
  1692. -- (22)设备漏洞变化趋势
  1693. -- 建表语句
  1694. DROP TABLE IF EXISTS `bi_panoramic_view_sb_ld_trend`;
  1695. CREATE TABLE `bi_panoramic_view_sb_ld_trend` (
  1696. `dtype` varchar(10) CHARACTER SET utf8mb4 NOT NULL DEFAULT '' COMMENT '日期类型',
  1697. `thedvalue` varchar(20) CHARACTER SET utf8mb4 DEFAULT NULL COMMENT '日期',
  1698. `app_name` varchar(50) NOT NULL DEFAULT '0' COMMENT '设备名称暂时没有数据',
  1699. `score_name` varchar(50) CHARACTER SET utf8mb4 NOT NULL DEFAULT '',
  1700. `the_score` double DEFAULT NULL
  1701. ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
  1702. truncate table bi_panoramic_view_sb_ld_trend;
  1703. insert into bi_panoramic_view_sb_ld_trend
  1704. select
  1705. 'DAY' as dtype,
  1706. thedvalue,
  1707. '' as app_name,
  1708. case b.mm when 1 then '安全设备漏洞' when 2 then '网络设备漏洞' when 3 then '终端PC漏洞' when 4 then '服务器漏洞' else '' end as score_name,
  1709. case b.mm when 1 then security_device_vul_total_count when 2 then network_device_vul_total_count when 3 then terminal_vul_total_count when 4 then server_vul_total_count else 0.0 end as the_score
  1710. from
  1711. (select
  1712. date_format(insert_time,'%Y%m%d') as thedvalue,
  1713. max(security_device_vul_total_count) + 0.0 as security_device_vul_total_count,
  1714. max(network_device_vul_total_count) + 0.0 as network_device_vul_total_count,
  1715. max(terminal_vul_total_count) + 0.0 as terminal_vul_total_count,
  1716. max(server_vul_total_count) + 0.0 as server_vul_total_count
  1717. from safe_index_info_1
  1718. group by date_format(insert_time,'%Y%m%d'),id) a
  1719. cross join
  1720. (select 1 mm
  1721. union all select 2
  1722. union all select 3
  1723. union all select 4) b;
  1724. insert into bi_panoramic_view_sb_ld_trend
  1725. select 'MONTH' as dtype,substring(thedvalue,1,6) AS thedvalue,
  1726. '' as app_name,score_name,avg(the_score) as the_score
  1727. from bi_panoramic_view_sb_ld_trend
  1728. where dtype = 'DAY'
  1729. GROUP BY substring(thedvalue,1,6),score_name;
  1730. insert into bi_panoramic_view_sb_ld_trend
  1731. select 'YEAR' as dtype,substring(thedvalue,1,4) AS thedvalue,
  1732. '' as app_name,score_name,avg(the_score) as the_score
  1733. from bi_panoramic_view_sb_ld_trend
  1734. where dtype = 'MONTH'
  1735. GROUP BY substring(thedvalue,1,4),score_name;
  1736. -- (23)设备准入变化趋势、双因子认证变化趋势、纳入4A变化趋势
  1737. -- 建表语句
  1738. DROP TABLE IF EXISTS `bi_panoramic_view_shaung_yin_a4_trend`;
  1739. CREATE TABLE `bi_panoramic_view_shaung_yin_a4_trend` (
  1740. `dtype` varchar(10) CHARACTER SET utf8mb4 NOT NULL DEFAULT '' COMMENT '日期类型',
  1741. `thedvalue` varchar(20) CHARACTER SET utf8mb4 DEFAULT NULL COMMENT '日期',
  1742. `id` varchar(50) NOT NULL DEFAULT '0' COMMENT '设备名称暂时没有数据',
  1743. `score_name` varchar(50) CHARACTER SET utf8mb4 NOT NULL DEFAULT '' COMMENT '指标名称',
  1744. `the_score` double DEFAULT NULL COMMENT '指标值'
  1745. ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
  1746. truncate table bi_panoramic_view_shaung_yin_a4_trend;
  1747. insert into bi_panoramic_view_shaung_yin_a4_trend
  1748. select
  1749. 'DAY' as dtype,
  1750. thedvalue,
  1751. case b.mm when 1 then '终端PC' when 2 then '终端PC' when 3 then '终端PC' when 4 then ''
  1752. when 5 then '' when 6 then '' when 7 then '' when 8 then '' else '' end as id,
  1753. case b.mm when 1 then '入网数' when 2 then '准入数' when 3 then '审计数' when 4 then '安全设备双因子认证'
  1754. when 5 then '网络设备双因子认证' when 6 then '服务器双因子认证' when 7 then '服务器4A' when 8 then '应用4A' else '' end as score_name,
  1755. case b.mm when 1 then dim1 when 2 then dim2 when 3 then dim3 when 4 then dim4
  1756. when 5 then dim5 when 6 then dim6 when 7 then dim7 when 8 then dim8 else 0.0 end as the_score
  1757. from
  1758. (select
  1759. date_format(insert_time,'%Y%m%d') as thedvalue,
  1760. max(terminal_count) + 0.0 as dim1,
  1761. max(terminal_admittance_count) + 0.0 as dim2,
  1762. max(terminal_audit_count) + 0.0 as dim3,
  1763. max(1.0 - security_device_unused_eactor_percent) + 0.0 as dim4,
  1764. max(1.0 - network_device_unused_factor_percent) + 0.0 as dim5,
  1765. max(1.0 - server_unused_factor_percent) + 0.0 as dim6,
  1766. max(1.0 - case when server_resource_failure_count + server_resource_success_count = 0 then 0.0 else server_resource_failure_count/(server_resource_failure_count + server_resource_success_count) * 1.0 end) + 0.0 as dim7,
  1767. max(1.0 - application_unused_factor_percent) as dim8
  1768. from safe_index_info_1
  1769. group by date_format(insert_time,'%Y%m%d'),id) a
  1770. cross join
  1771. (select 1 mm
  1772. union all select 2
  1773. union all select 3
  1774. union all select 4
  1775. union all select 5
  1776. union all select 6
  1777. union all select 7
  1778. union all select 8) b;
  1779. insert into bi_panoramic_view_shaung_yin_a4_trend
  1780. select 'MONTH' as dtype,substring(thedvalue,1,6) AS thedvalue,
  1781. id,score_name,avg(the_score) as the_score
  1782. from bi_panoramic_view_shaung_yin_a4_trend
  1783. where dtype = 'DAY'
  1784. GROUP BY substring(thedvalue,1,6),score_name,id;
  1785. insert into bi_panoramic_view_shaung_yin_a4_trend
  1786. select 'YEAR' as dtype,substring(thedvalue,1,4) AS thedvalue,
  1787. id,score_name,avg(the_score) as the_score
  1788. from bi_panoramic_view_shaung_yin_a4_trend
  1789. where dtype = 'MONTH'
  1790. GROUP BY substring(thedvalue,1,4),score_name,id;
  1791. -- (24)运维工单总量趋势、工单按时解决率趋势、各类工单未按时解决排名、工单满意度趋势、工单处理耗时排名、工单平均处理时长
  1792. -- 建表语句
  1793. DROP TABLE IF EXISTS `bi_work_flow_group_by_time`;
  1794. CREATE TABLE `bi_work_flow_group_by_time` (
  1795. `dtype` varchar(5) NOT NULL DEFAULT '' COMMENT '日期类型',
  1796. `thedvalue` varchar(15) DEFAULT NULL COMMENT '日期',
  1797. `process_type_name` varchar(255) CHARACTER SET utf8mb4 DEFAULT NULL COMMENT '流程定义类型名称',
  1798. `serve_area` varchar(32) CHARACTER SET utf8mb4 DEFAULT NULL COMMENT '所属区域',
  1799. `serve_department` varchar(32) CHARACTER SET utf8mb4 DEFAULT NULL COMMENT '所属部门',
  1800. `serve_firm` varchar(32) CHARACTER SET utf8mb4 DEFAULT NULL COMMENT '所属厂商',
  1801. `total_works` bigint(21) NOT NULL DEFAULT '0' COMMENT '工单总量',
  1802. `total_works_end` decimal(23,0) DEFAULT NULL COMMENT '已解决总量',
  1803. `total_works_noend` decimal(23,0) DEFAULT NULL COMMENT '未解决总量',
  1804. `total_works_notimeout` decimal(23,0) DEFAULT NULL COMMENT '未超时总量',
  1805. `total_works_timeout` decimal(23,0) DEFAULT NULL COMMENT '超时总量',
  1806. `total_time_consuming` double DEFAULT NULL COMMENT '总耗时',
  1807. `avg_time_consuming` double DEFAULT NULL COMMENT '平均耗时',
  1808. `satisfaction` double DEFAULT NULL COMMENT '满意度',
  1809. `app_id` varchar(20) DEFAULT NULL COMMENT 'appID'
  1810. ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
  1811. truncate table bi_work_flow_group_by_time;
  1812. insert into bi_work_flow_group_by_time
  1813. select
  1814. 'HOUR' as dtype,
  1815. date_format(a.start_time,'%Y%m%d%H') as thedvalue, -- str_to_date
  1816. a.process_type_name,
  1817. a.serve_area,
  1818. c.display_name as serve_department,
  1819. d.manufacturer_name as serve_firm,
  1820. count(*) as total_works,
  1821. sum(case when end_time is not null then 1 else 0 end) as total_works_end,
  1822. sum(case when end_time is not null then 0 else 1 end) as total_works_noend,
  1823. sum(case when time_out =1 then 1 else 0 end) as total_works_notimeout,
  1824. sum(case when time_out =0 then 1 else 0 end) as total_works_timeout,
  1825. sum(time_consuming) as total_time_consuming,
  1826. avg(time_consuming + 0.0) as avg_time_consuming,
  1827. avg(satisfaction + 0.0) as satisfaction,
  1828. b.app_id
  1829. from icm_bpm.t_work_flow a
  1830. left join icm_bpm.t_work_resource_real b
  1831. on a.id = b.work_id
  1832. left join icm.sys_org c
  1833. on a.serve_department = c.org_code
  1834. left join icm.cfg_manufacturer d
  1835. on a.handler_firm = d.id
  1836. group by
  1837. date_format(a.start_time,'%Y%m%d%H'),
  1838. a.process_type_name,
  1839. a.serve_area,
  1840. c.display_name,
  1841. d.manufacturer_name,b.app_id;
  1842. insert into bi_work_flow_group_by_time
  1843. select
  1844. 'DAY' as dtype,substring(thedvalue,1,8) AS thedvalue,
  1845. process_type_name,
  1846. serve_area,
  1847. serve_department,
  1848. serve_firm,
  1849. sum(total_works) as total_works,
  1850. sum(total_works_end) as total_works_end,
  1851. sum(total_works_noend) as total_works_noend,
  1852. sum(total_works_notimeout) as total_works_notimeout,
  1853. sum(total_works_timeout) as total_works_timeout,
  1854. sum(total_time_consuming) as total_time_consuming,
  1855. avg(avg_time_consuming + 0.0) as avg_time_consuming,
  1856. avg(satisfaction + 0.0) as satisfaction,
  1857. app_id
  1858. from bi_work_flow_group_by_time
  1859. where dtype = 'HOUR'
  1860. group by
  1861. substring(thedvalue,1,8),
  1862. process_type_name,
  1863. serve_area,
  1864. serve_department,
  1865. serve_firm,app_id;
  1866. insert into bi_work_flow_group_by_time
  1867. select
  1868. 'MONTH' as dtype,substring(thedvalue,1,6) AS thedvalue,
  1869. process_type_name,
  1870. serve_area,
  1871. serve_department,
  1872. serve_firm,
  1873. sum(total_works) as total_works,
  1874. sum(total_works_end) as total_works_end,
  1875. sum(total_works_noend) as total_works_noend,
  1876. sum(total_works_notimeout) as total_works_notimeout,
  1877. sum(total_works_timeout) as total_works_timeout,
  1878. sum(total_time_consuming) as total_time_consuming,
  1879. avg(avg_time_consuming + 0.0) as avg_time_consuming,
  1880. avg(satisfaction + 0.0) as satisfaction,
  1881. app_id
  1882. from bi_work_flow_group_by_time
  1883. where dtype = 'DAY'
  1884. group by
  1885. substring(thedvalue,1,6),
  1886. process_type_name,
  1887. serve_area,
  1888. serve_department,
  1889. serve_firm,app_id;
  1890. insert into bi_work_flow_group_by_time
  1891. select
  1892. 'YEAR' as dtype,substring(thedvalue,1,4) AS thedvalue,
  1893. process_type_name,
  1894. serve_area,
  1895. serve_department,
  1896. serve_firm,
  1897. sum(total_works) as total_works,
  1898. sum(total_works_end) as total_works_end,
  1899. sum(total_works_noend) as total_works_noend,
  1900. sum(total_works_notimeout) as total_works_notimeout,
  1901. sum(total_works_timeout) as total_works_timeout,
  1902. sum(total_time_consuming) as total_time_consuming,
  1903. avg(avg_time_consuming + 0.0) as avg_time_consuming,
  1904. avg(satisfaction + 0.0) as satisfaction,
  1905. app_id
  1906. from bi_work_flow_group_by_time
  1907. where dtype = 'MONTH'
  1908. group by
  1909. substring(thedvalue,1,4),
  1910. process_type_name,
  1911. serve_area,
  1912. serve_department,
  1913. serve_firm,app_id;
  1914. -- (26)最高法院效能分析排序
  1915. -- 建表语句
  1916. DROP TABLE IF EXISTS `bi_app_stat_group_transposed`;
  1917. CREATE TABLE `bi_app_stat_group_transposed` (
  1918. `thedvalue` varchar(20) DEFAULT NULL COMMENT '日期',
  1919. `itm_hardware_resources_id` varchar(200) NOT NULL DEFAULT '' COMMENT '告警设备ID',
  1920. `ITM_HARDWARE_RESOURCES_NAME` varchar(255) DEFAULT NULL COMMENT '设备名称',
  1921. `col_name` varchar(200) CHARACTER SET utf8mb4 NOT NULL DEFAULT '',
  1922. `col_value` decimal(24,10) DEFAULT NULL,
  1923. KEY `idx_1` (`thedvalue`,`col_name`) USING BTREE
  1924. ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
  1925. truncate table bi_app_stat_group_transposed;
  1926. insert into bi_app_stat_group_transposed
  1927. select
  1928. thedvalue,itm_hardware_resources_id,ITM_HARDWARE_RESOURCES_NAME,
  1929. case b.mm when 1 then 'CPU平均利用率' when 2 then 'CPU峰值利用率' when 3 then '内存平均利用率' when 4 then '内存峰值利用率'
  1930. when 5 then '磁盘利用率' when 6 then '带宽平均利用率' when 7 then '带宽峰值利用率' when 8 then '交换机错包率' when 9 then '交换机丢包率' else '' end as col_name,
  1931. case b.mm when 1 then dim1 when 2 then dim2 when 3 then dim3 when 4 then dim4
  1932. when 5 then dim5 when 6 then dim6 when 7 then dim7 when 8 then dim8 when 9 then dim9 else 0.0 end as col_value
  1933. from (
  1934. select
  1935. thedvalue,itm_hardware_resources_id,ITM_HARDWARE_RESOURCES_NAME,
  1936. avg(IND_VALUE_Network_Cpurate) as dim1,max(IND_VALUE_Network_Cpurate_High) as dim2,avg(IND_VALUE_Network_Memrate) as dim3,avg(IND_VALUE_Network_Memrate_High) as dim4,
  1937. avg(IND_VALUE_HOST_DISK_UTILIZATION) as dim5,avg(Band_widthrate) as dim6,max(Bandwidthrate_High) as dim7,avg(Network_PacketLossrate) as dim8,avg(Network_PacketErrorrate) as dim9
  1938. from bi_app_stat_group_by_time
  1939. where dtype = 'DAY' and QGorZG = '最高'
  1940. group by thedvalue,itm_hardware_resources_id,ITM_HARDWARE_RESOURCES_NAME) a
  1941. cross join
  1942. (select 1 mm
  1943. union all select 2
  1944. union all select 3
  1945. union all select 4
  1946. union all select 5
  1947. union all select 6
  1948. union all select 7
  1949. union all select 8
  1950. union all select 9) b;
  1951. -- (27)应用系统业务指标
  1952. -- 建表语句
  1953. DROP TABLE IF EXISTS `bi_app_tsc_stat`;
  1954. CREATE TABLE `bi_app_tsc_stat` (
  1955. `dtype` varchar(10) NOT NULL DEFAULT '' COMMENT '日期类型',
  1956. `thedvalue` varchar(12) DEFAULT NULL COMMENT '日期',
  1957. `app_id` varchar(20) NOT NULL DEFAULT '' COMMENT 'appID',
  1958. `app_name` varchar(255) NOT NULL DEFAULT '' COMMENT 'app名称',
  1959. `dim` varchar(255) NOT NULL DEFAULT '' COMMENT '维度',
  1960. `dim_tuli` varchar(255) DEFAULT NULL COMMENT '图例',
  1961. `dim_value` decimal(20,2) DEFAULT NULL COMMENT '指标值',
  1962. `dim_value_unit` varchar(255) DEFAULT NULL COMMENT '指标单位',
  1963. `value_calculate` varchar(255) DEFAULT NULL COMMENT '指标计算方式',
  1964. `dim_tuli_value` decimal(20,2) DEFAULT NULL COMMENT '图例值'
  1965. ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
  1966. drop procedure if exists wk_app_new;
  1967. delimiter $$
  1968. create procedure wk_app_new()
  1969. begin
  1970. declare i int default 0;
  1971. declare continue_handler int default 0;
  1972. declare c_app_id varchar(200);
  1973. declare c_app_name varchar(200);
  1974. declare c_fieldname varchar(64);
  1975. declare c_fielddesc varchar(64);
  1976. declare c_statmodel varchar(255);
  1977. declare c_quotaUnit varchar(10);
  1978. declare c1 cursor for
  1979. select
  1980. distinct a.APP_ID,a.APP_NAME,b.fieldname,b.fielddesc,b.statmodel,b.quotaUnit
  1981. from
  1982. (select distinct ITM_APP_ID as APP_ID,ITM_APP_NAME as APP_NAME from itm_app) a
  1983. left join
  1984. (select a.appid,a.fieldname,a.fielddesc,a.statmodel,a.quotaUnit
  1985. from itm_app_tsc_set a where transtype = '62' and showType = 'line') b
  1986. on a.APP_ID = b.appid
  1987. where (fieldname is not null) and (statmodel is not null and statmodel != '');
  1988. declare c2 cursor for
  1989. select
  1990. distinct a.APP_ID,a.APP_NAME,b.fieldname,b.fielddesc,b.statmodel,b.quotaUnit
  1991. from
  1992. (select distinct ITM_APP_ID as APP_ID,ITM_APP_NAME as APP_NAME from itm_app) a
  1993. left join
  1994. (select distinct a.appid,a.fieldname,b.fielddesc,a.statmodel,a.quotaUnit
  1995. from
  1996. (select appid,fieldname,fielddesc,statmodel,quotaUnit,showType from itm_app_tsc_set where transtype = '62') a
  1997. left join
  1998. (select appid,fieldname,fielddesc,statmodel,quotaUnit,showType from itm_app_tsc_set where transtype = '62') b
  1999. on a.appid = b.appid and a.fieldname = b.fieldname
  2000. where a.showType = 'bar' and b.showType = 'line') b
  2001. on a.APP_ID = b.appid
  2002. where (fieldname is not null) and (statmodel is not null and statmodel != '');
  2003. declare continue handler for not found set i=1;
  2004. declare continue handler for sqlexception,sqlwarning set continue_handler=1;
  2005. open c1;
  2006. while i = 0 do
  2007. fetch c1 into c_app_id,c_app_name,c_fieldname,c_fielddesc,c_statmodel,c_quotaUnit;
  2008. set @need_sql=concat("
  2009. insert into bi_app_tsc_stat
  2010. select \'MONTH\' as dtype,date_format(TRANSED_DT,\'%Y%m\') as thedvalue,\'',c_app_id,'\' as app_id,\'',c_app_name,'\' as app_name,\'',c_fielddesc,'\' as dim,\'',c_fielddesc,'\' as dim_tuli,'
  2011. ,c_statmodel,'(',c_fieldname,') as dim_value,\'',c_quotaUnit,'\' as dim_value_unit,\'',c_statmodel,'\' as value_calculate,null as dim_tuli_value
  2012. from t_ind_obj_app_tsc_stat where APP_ID = \'',c_app_id, '\' and TRANS_TYPE = \'62\' and (CEXT0 is null or CEXT0 = \'\')
  2013. group by date_format(TRANSED_DT,\'%Y%m\')");
  2014. PREPARE final_sql FROM @need_sql;
  2015. EXECUTE final_sql;
  2016. -- if continue_handler = 1 THEN
  2017. -- insert into bi_app_tsc_default values(c_app_id,c_app_name,c_fieldname,c_fielddesc,c_statmodel,c_quotaUnit);
  2018. -- end if;
  2019. end while;
  2020. close c1;
  2021. set i = 0;
  2022. open c2;
  2023. while i = 0 do
  2024. fetch c2 into c_app_id,c_app_name,c_fieldname,c_fielddesc,c_statmodel,c_quotaUnit;
  2025. set @need_sql=concat("
  2026. insert into bi_app_tsc_stat
  2027. select \'MONTH\' as dtype,date_format(TRANSED_DT,\'%Y%m\') as thedvalue,\'',c_app_id,'\' as app_id,\'',c_app_name,'\' as app_name,\'',c_fielddesc,'\' as dim,CEXT0 as dim_tuli,
  2028. null as dim_value,\'',c_quotaUnit,'\' as dim_value_unit,\'',c_statmodel,'\' as value_calculate,',c_statmodel,'(',c_fieldname,') as dim_value
  2029. from t_ind_obj_app_tsc_stat where APP_ID = \'',c_app_id, '\' and TRANS_TYPE = \'62\' and CEXT0 is not null and cext0 != \'\'
  2030. group by date_format(TRANSED_DT,\'%Y%m\'), CEXT0");
  2031. PREPARE final_sql FROM @need_sql;
  2032. EXECUTE final_sql;
  2033. -- if continue_handler = 1 THEN
  2034. -- insert into bi_app_tsc_default values(c_app_id,c_app_name,c_fieldname,c_fielddesc,c_statmodel,c_quotaUnit);
  2035. -- end if;
  2036. end while;
  2037. close c2;
  2038. end $$
  2039. delimiter ;
  2040. -- truncate table bi_app_tsc_default;
  2041. truncate table bi_app_tsc_stat;
  2042. call wk_app_new();
  2043. delete from bi_app_tsc_stat where dtype = 'YEAR';
  2044. insert into bi_app_tsc_stat
  2045. select 'YEAR' as dtype,substring(thedvalue,1,4) as thedvalue,app_id,app_name,dim,dim_tuli,sum(dim_value) as dim_value,dim_value_unit,value_calculate,sum(dim_tuli_value) as dim_tuli_value
  2046. from bi_app_tsc_stat where dtype = 'MONTH' and value_calculate = 'SUM'
  2047. group by substring(thedvalue,1,4), app_id, app_name, dim,dim_tuli,dim_value_unit,value_calculate
  2048. union all
  2049. select 'YEAR' as dtype,substring(thedvalue,1,4) as thedvalue,app_id,app_name,dim,dim_tuli,avg(dim_value) as dim_value,dim_value_unit,value_calculate,avg(dim_tuli_value) as dim_tuli_value
  2050. from bi_app_tsc_stat where dtype = 'MONTH' and value_calculate = 'AVG'
  2051. group by substring(thedvalue,1,4), app_id, app_name, dim,dim_tuli,dim_value_unit,value_calculate
  2052. union all
  2053. select 'YEAR' as dtype,substring(thedvalue,1,4) as thedvalue,app_id,app_name,dim,dim_tuli,max(dim_value) as dim_value,dim_value_unit,value_calculate,max(dim_tuli_value) as dim_tuli_value
  2054. from bi_app_tsc_stat where dtype = 'MONTH' and value_calculate = 'MAX'
  2055. group by substring(thedvalue,1,4), app_id, app_name, dim,dim_tuli,dim_value_unit,value_calculate
  2056. union all
  2057. select 'YEAR' as dtype,substring(thedvalue,1,4) as thedvalue,app_id,app_name,dim,dim_tuli,min(dim_value) as dim_value,dim_value_unit,value_calculate ,min(dim_tuli_value) as dim_tuli_value
  2058. from bi_app_tsc_stat where dtype = 'MONTH' and value_calculate = 'MIN'
  2059. group by substring(thedvalue,1,4), app_id, app_name, dim,dim_tuli,dim_value_unit,value_calculate;
  2060. -- (28) 工单报表
  2061. -- 建表语句
  2062. DROP TABLE IF EXISTS `bi_workflow`;
  2063. CREATE TABLE `bi_workflow` (
  2064. `before_handler` varchar(255) DEFAULT NULL,
  2065. `a_id` varchar(255) NOT NULL COMMENT '主键id',
  2066. `theme` varchar(255) DEFAULT NULL COMMENT '工单主题',
  2067. `proposer_phone` varchar(255) DEFAULT NULL COMMENT '申请人联系方式',
  2068. `proposer_name` varchar(255) DEFAULT NULL COMMENT '申请人姓名',
  2069. `proposer` varchar(255) DEFAULT NULL COMMENT '申请人id',
  2070. `serial_number` varchar(255) DEFAULT NULL COMMENT '工单流水号',
  2071. `process_key` varchar(255) DEFAULT NULL COMMENT '流程定义的key',
  2072. `serve_type` varchar(255) DEFAULT NULL COMMENT '服务类型',
  2073. `process_id` varchar(255) DEFAULT NULL COMMENT '流程定义id',
  2074. `parent_process_type_name` varchar(255) DEFAULT NULL COMMENT '流程定义类型名称',
  2075. `process_type` varchar(255) DEFAULT NULL COMMENT '流程定义类型名称',
  2076. `setting_data` longtext COMMENT '流程定义设置信息json格式数据',
  2077. `process_type_name` varchar(64) DEFAULT NULL,
  2078. `parent_process_type` varchar(64) DEFAULT NULL,
  2079. `form_key` varchar(255) DEFAULT NULL,
  2080. `form_data` longtext COMMENT '对应的自定义表单json格式数据',
  2081. `urg_degree` varchar(255) DEFAULT NULL COMMENT '工单紧急程度',
  2082. `start_account` varchar(255) DEFAULT NULL COMMENT '发起人',
  2083. `start_account_id` varchar(255) DEFAULT NULL COMMENT '发起人id',
  2084. `start_account_phone` varchar(32) DEFAULT NULL,
  2085. `expect_time` varchar(255) DEFAULT NULL COMMENT '期望完成时间',
  2086. `end_time` varchar(255) DEFAULT NULL COMMENT '完成时间',
  2087. `start_time` varchar(255) DEFAULT NULL COMMENT '开始时间',
  2088. `process_status` varchar(255) DEFAULT NULL COMMENT '流程状态',
  2089. `handler` longtext COMMENT '待处理人',
  2090. `next_handler` varchar(255) DEFAULT NULL COMMENT '下一环节处理人',
  2091. `attention` varchar(64) DEFAULT NULL COMMENT '关注状态',
  2092. `node_id` varchar(64) DEFAULT NULL COMMENT '流程节点id',
  2093. `press` tinyint(4) DEFAULT '0' COMMENT '催办状态 0表示未催办 1表示催办',
  2094. `opinion` varchar(255) DEFAULT NULL COMMENT '审批意见',
  2095. `result` int(11) DEFAULT NULL COMMENT '审批结果',
  2096. `form_id` varchar(255) DEFAULT NULL COMMENT '自定义表单id',
  2097. `proc_def_id` varchar(255) DEFAULT NULL COMMENT '流程部署id',
  2098. `relevance` varchar(64) DEFAULT NULL COMMENT '关联状态',
  2099. `handler_name` varchar(255) DEFAULT NULL COMMENT '待处理人姓名',
  2100. `next_handler_name` varchar(255) DEFAULT NULL COMMENT '下一节点处理人姓名',
  2101. `node_type` varchar(255) DEFAULT NULL COMMENT '节点类型',
  2102. `update_time` varchar(255) DEFAULT NULL COMMENT '更新时间',
  2103. `appraise` tinyint(4) DEFAULT NULL COMMENT '工单是否已评价 0已评价 1未评价',
  2104. `failure_type` varchar(255) DEFAULT NULL,
  2105. `satisfaction` varchar(32) DEFAULT NULL COMMENT '满意度',
  2106. `serve_department` varchar(32) DEFAULT NULL COMMENT '发起人所属部门',
  2107. `serve_firm` varchar(32) DEFAULT NULL COMMENT '发起人所属厂商',
  2108. `serve_area` varchar(32) DEFAULT NULL COMMENT '发起人所属区域',
  2109. `time_consuming` varchar(32) DEFAULT NULL COMMENT '工单耗时',
  2110. `time_out` varchar(32) DEFAULT NULL COMMENT '是否超时 0超时 1未超时',
  2111. `performance` varchar(255) DEFAULT NULL COMMENT '绩效得分',
  2112. `proposer_serve_department` varchar(255) DEFAULT NULL COMMENT '申请人所属部门',
  2113. `proposer_serve_firm` varchar(255) DEFAULT NULL COMMENT '申请人所属厂商',
  2114. `proposer_serve_area` varchar(255) DEFAULT NULL COMMENT '申请人所属区域',
  2115. `start_user` varchar(255) DEFAULT NULL,
  2116. `order_desc` varchar(255) DEFAULT NULL COMMENT '工单描述',
  2117. `cocall` varchar(255) DEFAULT NULL,
  2118. `handler_firm` longtext,
  2119. `b_id` int(11) DEFAULT '0',
  2120. `work_id` varchar(32) DEFAULT NULL COMMENT '工单id',
  2121. `alarm_uuid` varchar(255) DEFAULT NULL COMMENT '告警uuid',
  2122. `alarm_type` varchar(32) DEFAULT NULL COMMENT '告警类型',
  2123. `object_id` varchar(255) DEFAULT NULL,
  2124. `app_id` varchar(64) DEFAULT NULL,
  2125. `c` varchar(255) CHARACTER SET utf8 DEFAULT NULL COMMENT '设备名称'
  2126. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
  2127. truncate table bi_workflow;
  2128. insert into bi_workflow
  2129. select '',a.id as a_id,theme,proposer_phone,proposer_name,proposer,serial_number,process_key,serve_type,process_id,parent_process_type_name,process_type,setting_data,process_type_name,parent_process_type,form_key,form_data,urg_degree,start_account,start_account_id,start_account_phone,expect_time,end_time,start_time,process_status,handler,next_handler,attention,node_id,press,opinion,result,form_id,proc_def_id,relevance,handler_name,next_handler_name,node_type,a.update_time,appraise,failure_type,satisfaction,serve_department,serve_firm,serve_area,time_consuming,
  2130. time_out,performance,proposer_serve_department,proposer_serve_firm,proposer_serve_area,start_user,order_desc,cocall,handler_firm,b.id as b_id,work_id,alarm_uuid,alarm_type,object_id,app_id,ihr.ITM_HARDWARE_RESOURCES_NAME c
  2131. from icm_bpm.t_work_flow a
  2132. left join icm_bpm.t_work_resource_real b on a.id = b.work_id
  2133. left join itm_hardware_resources ihr on ihr.itm_hardware_resources_id = b.object_id;
  2134. -- 结构化数据容量分析
  2135. -- 建表语句
  2136. DROP TABLE IF EXISTS `bi_structured_data_capacity`;
  2137. CREATE TABLE `bi_structured_data_capacity` (
  2138. `dtype` varchar(5) NOT NULL DEFAULT '' COMMENT '日期类型',
  2139. `thedvalue` varchar(20) DEFAULT NULL COMMENT '日期',
  2140. `NET_ID` varchar(64) DEFAULT NULL COMMENT '网系ID',
  2141. `NET_NAME` varchar(64) DEFAULT NULL COMMENT '网系名称',
  2142. `ORGAN_ID` varchar(100) DEFAULT NULL COMMENT '区域ID',
  2143. `ORGAN_NAME` varchar(100) DEFAULT NULL COMMENT '区域名称',
  2144. `totalsize` varchar(255) DEFAULT NULL COMMENT '当前数据库对应数量存储量 单位是GB'
  2145. ) ENGINE = InnoDB DEFAULT CHARSET = utf8;
  2146. truncate table bi_structured_data_capacity;
  2147. insert into bi_structured_data_capacity
  2148. select
  2149. 'DAY' as dtype,
  2150. date_format(IND_VALUE_TIME,'%Y%m%d') as thedvalue,
  2151. adds.NETID,
  2152. d.name,
  2153. adds.ORGAN_ID,
  2154. po.short_name,
  2155. SUM(adds.totalsize)
  2156. from app_db_detail_stat adds
  2157. left join (select value,name from m_com_dict where dict_index='itm_resources_netcode') d on d.value=adds.NETID
  2158. left join pub_organ po on po.ID=adds.ORGAN_ID
  2159. group by date_format(IND_VALUE_TIME,'%Y%m%d'),adds.NETID,adds.ORGAN_ID,d.name,po.short_name;
  2160. insert into bi_structured_data_capacity
  2161. select 'MONTH' as dtype,substring(thedvalue,1,6) AS thedvalue,
  2162. NET_ID,NET_NAME, ORGAN_ID,ORGAN_NAME, SUM(totalsize)
  2163. from bi_structured_data_capacity
  2164. where dtype = 'DAY'
  2165. GROUP BY substring(thedvalue,1,6),NET_ID,NET_NAME,ORGAN_ID,ORGAN_NAME;
  2166. insert into bi_structured_data_capacity
  2167. select 'YEAR' as dtype,substring(thedvalue,1,4) AS thedvalue,
  2168. NET_ID,NET_NAME, ORGAN_ID,ORGAN_NAME, SUM(totalsize)
  2169. from bi_structured_data_capacity
  2170. where dtype = 'MONTH'
  2171. GROUP BY substring(thedvalue,1,4),NET_ID,NET_NAME,ORGAN_ID,ORGAN_NAME;
  2172. -- 存储使用率占比分析
  2173. -- 建表语句
  2174. DROP TABLE IF EXISTS `bi_storage_usage_rate`;
  2175. CREATE TABLE `bi_storage_usage_rate` (
  2176. `dtype` varchar(5) NOT NULL DEFAULT '' COMMENT '日期类型',
  2177. `thedvalue` varchar(20) DEFAULT NULL COMMENT '日期',
  2178. `NET_ID` varchar(64) DEFAULT NULL COMMENT '网系ID',
  2179. `NET_NAME` varchar(64) DEFAULT NULL COMMENT '网系名称',
  2180. `ORGAN_ID` varchar(100) DEFAULT NULL COMMENT '区域ID',
  2181. `ORGAN_NAME` varchar(100) DEFAULT NULL COMMENT '区域名称',
  2182. `used` decimal(20,10) DEFAULT NULL COMMENT '存储使用量',
  2183. `total` decimal(20,10) DEFAULT NULL COMMENT '存储总量',
  2184. `usage_rate` decimal(20,10) DEFAULT NULL COMMENT '存储使用率'
  2185. ) ENGINE = InnoDB DEFAULT CHARSET = utf8;
  2186. truncate table bi_storage_usage_rate;
  2187. insert into bi_storage_usage_rate
  2188. select
  2189. 'DAY' as dtype,
  2190. date_format(IND_VALUE_TIME,'%Y%m%d') as thedvalue,
  2191. asds.NETID,
  2192. d.name,
  2193. asds.ORGAN_ID,
  2194. po.short_name,
  2195. SUM(asds.IND_VALUE_StorageDevice_UsedSpace),
  2196. SUM(asds.IND_VALUE_StorageDevice_TotalSpace),
  2197. SUM(asds.IND_VALUE_StorageDevice_UsedSpace) / SUM(asds.IND_VALUE_StorageDevice_TotalSpace) as 'usage_rate'
  2198. from app_storage_day_stat asds
  2199. left join (select value,name from m_com_dict where dict_index='itm_resources_netcode') d on d.value=asds.NETID
  2200. left join pub_organ po on po.ID=asds.ORGAN_ID
  2201. group by date_format(IND_VALUE_TIME,'%Y%m%d'),asds.NETID,asds.ORGAN_ID,d.name,po.short_name;
  2202. insert into bi_storage_usage_rate
  2203. select 'MONTH' as dtype,substring(thedvalue,1,6) AS thedvalue,
  2204. NET_ID, NET_NAME,ORGAN_ID,ORGAN_NAME, SUM(used), SUM(total), SUM(used)/SUM(total)
  2205. from bi_storage_usage_rate
  2206. where dtype = 'DAY'
  2207. GROUP BY substring(thedvalue,1,6),NET_ID,ORGAN_ID,NET_NAME,ORGAN_NAME;
  2208. insert into bi_storage_usage_rate
  2209. select 'YEAR' as dtype,substring(thedvalue,1,4) AS thedvalue,
  2210. NET_ID, NET_NAME,ORGAN_ID,ORGAN_NAME, SUM(used), SUM(total), SUM(used)/SUM(total)
  2211. from bi_storage_usage_rate
  2212. where dtype = 'MONTH'
  2213. GROUP BY substring(thedvalue,1,4),NET_ID,ORGAN_ID,NET_NAME,ORGAN_NAME;
  2214. -- 应用数据分析
  2215. -- 建表语句
  2216. DROP TABLE IF EXISTS `bi_app_data_analysis`;
  2217. CREATE TABLE `bi_app_data_analysis` (
  2218. `dtype` varchar(5) NOT NULL DEFAULT '' COMMENT '日期类型',
  2219. `thedvalue` varchar(20) DEFAULT NULL COMMENT '日期',
  2220. `NET_ID` varchar(64) DEFAULT NULL COMMENT '网系ID',
  2221. `NET_NAME` varchar(64) DEFAULT NULL COMMENT '网系名称',
  2222. `ORGAN_ID` varchar(100) DEFAULT NULL COMMENT '区域ID',
  2223. `ORGAN_NAME` varchar(100) DEFAULT NULL COMMENT '区域名称',
  2224. `app_id` varchar(64) DEFAULT NULL COMMENT '应用ID',
  2225. `app_name` varchar(255) DEFAULT NULL COMMENT '应用名称',
  2226. `priority` varchar(10) DEFAULT NULL COMMENT '优先级:核心-high;重要-important;一般-low',
  2227. `visit_count` decimal(20,2) DEFAULT NULL COMMENT '访问量',
  2228. `user_count` decimal(20,2) DEFAULT NULL COMMENT '用户量',
  2229. `quality` decimal(20,6) DEFAULT NULL COMMENT '数据质量'
  2230. ) ENGINE = InnoDB DEFAULT CHARSET = utf8;
  2231. truncate table bi_app_data_analysis;
  2232. insert into bi_app_data_analysis
  2233. select
  2234. 'MONTH' as dtype,
  2235. date_format(visit_time,'%Y%m') as thedvalue,
  2236. ia.ITM_NETGROUP_ID,
  2237. d.name,
  2238. arl.organ_id,
  2239. po.short_name,
  2240. arl.app_id,
  2241. ia.itm_app_name,
  2242. ia.PRIORITY,
  2243. sum(arl.visit_count),
  2244. sum(arl.user_count),
  2245. 0.0
  2246. from app_region_log arl
  2247. left join itm_app ia on ia.ITM_APP_ID=arl.app_id
  2248. left join (select value,name from m_com_dict where dict_index='itm_resources_netcode') d on d.value=ia.ITM_NETGROUP_ID
  2249. left join pub_organ po on po.id=CAST(arl.organ_id AS CHAR)
  2250. group by date_format(visit_time,'%Y%m'),ia.ITM_NETGROUP_ID,arl.organ_id,arl.app_id,ia.itm_app_name,ia.PRIORITY,d.name,po.short_name;
  2251. insert into bi_app_data_analysis
  2252. select
  2253. 'MONTH' as dtype,
  2254. replace(aadq.`month`,'-','') as thedvalue,
  2255. ia.ITM_NETGROUP_ID,
  2256. d.name,
  2257. ia.organ_id,
  2258. po.name,
  2259. ia.ITM_APP_ID,
  2260. ia.itm_app_name,
  2261. ia.PRIORITY,
  2262. 0,
  2263. 0,
  2264. sum(aadq.quality)
  2265. from t_asset_app_data_quality aadq
  2266. left join itm_app ia on ia.ITM_APP_ID=aadq.app_id
  2267. left join (select value,name from m_com_dict where dict_index='itm_resources_netcode') d on d.value=ia.ITM_NETGROUP_ID
  2268. left join pub_organ po on po.ID=ia.organ_id
  2269. group by replace(aadq.`month`,'-',''),ia.ITM_NETGROUP_ID,ia.organ_id,ia.ITM_APP_ID,ia.itm_app_name,ia.PRIORITY,d.name,po.name;
  2270. insert into bi_app_data_analysis
  2271. select 'YEAR' as dtype,substring(thedvalue,1,4) AS thedvalue,
  2272. NET_ID,NET_NAME,ORGAN_ID,ORGAN_NAME,app_id,app_name,priority,sum(visit_count),sum(user_count),sum(quality)
  2273. from bi_app_data_analysis
  2274. where dtype = 'MONTH'
  2275. GROUP BY substring(thedvalue,1,4),NET_ID,NET_NAME,ORGAN_ID,ORGAN_NAME,app_id,app_name,priority;
  2276. -- 应用备份覆盖率分析
  2277. -- 建表语句
  2278. DROP TABLE IF EXISTS `bi_app_backup_coverage`;
  2279. CREATE TABLE `bi_app_backup_coverage` (
  2280. `dtype` varchar(5) NOT NULL DEFAULT '' COMMENT '日期类型',
  2281. `thedvalue` varchar(20) DEFAULT NULL COMMENT '日期',
  2282. `NET_ID` varchar(64) DEFAULT NULL COMMENT '网系ID',
  2283. `NET_NAME` varchar(64) DEFAULT NULL COMMENT '网系名称',
  2284. `ORGAN_ID` varchar(100) DEFAULT NULL COMMENT '区域ID',
  2285. `ORGAN_NAME` varchar(100) DEFAULT NULL COMMENT '区域名称',
  2286. `app_id` varchar(64) DEFAULT NULL COMMENT '应用ID',
  2287. `app_name` varchar(255) DEFAULT NULL COMMENT '应用名称',
  2288. `priority` varchar(10) DEFAULT NULL COMMENT '优先级:核心-high;重要-important;一般-low',
  2289. `bak_size` decimal(20,10) DEFAULT NULL COMMENT '备份数据容量',
  2290. `total_size` decimal(20,10) DEFAULT NULL COMMENT '总容量',
  2291. `backup_coverage` decimal(20,10) DEFAULT NULL COMMENT '备份覆盖率'
  2292. ) ENGINE = InnoDB DEFAULT CHARSET = utf8;
  2293. truncate table bi_app_backup_coverage;
  2294. insert into bi_app_backup_coverage
  2295. select
  2296. 'MONTH' as dtype,
  2297. replace(abi.`month`,'-','') as thedvalue,
  2298. ia.ITM_NETGROUP_ID,
  2299. d.name,
  2300. ia.ORGAN_ID,
  2301. po.short_name,
  2302. abi.app_id,
  2303. ia.ITM_APP_NAME,
  2304. ia.PRIORITY,
  2305. sum(abi.bak_size),
  2306. sum(abi.total_size),
  2307. IF(sum(abi.total_size)<>0, sum(abi.bak_size) / sum(abi.total_size), 0)
  2308. from t_asset_app_bak_info abi
  2309. left join itm_app ia on ia.ITM_APP_ID=abi.app_id
  2310. left join (select value,name from m_com_dict where dict_index='itm_resources_netcode') d on d.value=ia.ITM_NETGROUP_ID
  2311. left join pub_organ po on po.id=ia.ORGAN_ID
  2312. group by replace(abi.`month`,'-',''),ia.ITM_NETGROUP_ID,ia.ORGAN_ID,abi.app_id,ia.ITM_APP_NAME,ia.PRIORITY,d.name,po.short_name;
  2313. insert into bi_app_backup_coverage
  2314. select 'YEAR' as dtype,substring(thedvalue,1,4) AS thedvalue,
  2315. NET_ID,NET_NAME,ORGAN_ID,ORGAN_NAME,app_id,app_name,priority,
  2316. sum(bak_size),
  2317. sum(total_size),
  2318. IF(sum(total_size)<>0, sum(bak_size) / sum(total_size), 0)
  2319. from bi_app_backup_coverage
  2320. where dtype = 'MONTH'
  2321. GROUP BY substring(thedvalue,1,4),NET_ID,NET_NAME,ORGAN_ID,ORGAN_NAME,app_id,app_name,priority;
  2322. set sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION';
  2323. DROP TABLE IF EXISTS `bi_app_resource_group_by_time`;
  2324. CREATE TABLE `bi_app_resource_group_by_time` (
  2325. `dtype` varchar(5) NOT NULL DEFAULT '' COMMENT '日期类型',
  2326. `thedvalue` varchar(15) DEFAULT NULL COMMENT '日期',
  2327. `dhour` varchar(15) DEFAULT NULL comment '小时',
  2328. `ITM_APP_ID` varchar(255) NOT NULL COMMENT '应用ID',
  2329. `ITM_APP_CODE` varchar(45) DEFAULT NULL COMMENT '编码',
  2330. `ITM_APP_NAME` varchar(200) DEFAULT NULL COMMENT '应用名称',
  2331. `ITM_APP_SHORTNAME` varchar(100) DEFAULT NULL COMMENT '应用简称',
  2332. `ITM_APP_DESC` text COMMENT '系统简介',
  2333. `ITM_APP_DEPT` varchar(300) DEFAULT NULL COMMENT '归口部门',
  2334. `ITM_APP_COURTCODE` varchar(45) DEFAULT NULL COMMENT '承建单位\n例如:最高法、山东省高法\n取法院系统的组织机构编码',
  2335. `ITM_NETGROUP_ID` varchar(30) DEFAULT NULL COMMENT '应用所属网系\n更新字典表\nNG000:外部专网\nNG001:法院专网\nNG002:互联网\nNG003:移动专网\nNG004:涉密内网',
  2336. `ITM_APPCATAGORY_ID` varchar(45) DEFAULT NULL,
  2337. `ITM_APP_VENDOR` varchar(45) DEFAULT NULL COMMENT '供应商:浪潮、太极等',
  2338. `ITM_APP_UPTIME` datetime DEFAULT NULL COMMENT '上线时间',
  2339. `ITM_APP_VERSION` varchar(45) DEFAULT NULL,
  2340. `ITM_APP_MAINTENANCE_ID` varchar(45) DEFAULT NULL COMMENT '运维团队,关联运维表,使用内码连接\n',
  2341. `ITM_APP_ORDER` int(45) DEFAULT NULL COMMENT '应用顺序,展示',
  2342. `ITM_APP_NETID` varchar(45) DEFAULT NULL COMMENT '专网编号',
  2343. `ITM_APP_ICONSRC` varchar(100) DEFAULT NULL COMMENT '应用分类\n三类和25类字典表表现',
  2344. `ITM_APP_SYSTEMURL` varchar(100) DEFAULT NULL COMMENT '',
  2345. `ORGAN_ID` varchar(30) DEFAULT NULL COMMENT '机构id,关联机构表',
  2346. `IS_GLOBAL` varchar(45) DEFAULT NULL COMMENT '是否是全局\n如果是全局,则拓扑图是全局的\n如果是非全局,需要维护各自的',
  2347. `ITM_APP_PID` varchar(45) DEFAULT NULL COMMENT '父类系统\n',
  2348. `PLATFORM` varchar(100) DEFAULT NULL COMMENT '七大平台',
  2349. `PRIORITY` varchar(10) DEFAULT NULL COMMENT '优先级:核心-high,重要-important,一般-low',
  2350. `ITM_APP_IP` varchar(30) DEFAULT NULL COMMENT '应用所在服务器IP',
  2351. `ITM_APP_PORT` varchar(10) DEFAULT NULL COMMENT '应用所在服务器端口',
  2352. `ITM_APP_WEBROOT` varchar(100) DEFAULT NULL COMMENT '应用访问路径根目录',
  2353. `ITM_LOCATION` varchar(100) DEFAULT NULL COMMENT '位置信息',
  2354. `ITM_APP_ASSURE_LEVEL` varchar(1) DEFAULT NULL COMMENT '应用保障级别1一级保障',
  2355. `SHOW_TYPE` varchar(10) DEFAULT NULL,
  2356. `ITM_SHOW_FLAG` varchar(10) DEFAULT NULL,
  2357. `int_id` int(22) DEFAULT NULL COMMENT '其他系统关联用ID',
  2358. `INSERT_TIME` timestamp NULL DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP COMMENT '记录插入时间',
  2359. `mantance_vendor` varchar(64) DEFAULT NULL,
  2360. `mantance_duty` varchar(64) DEFAULT NULL,
  2361. `mantance_duty_phone` varchar(128) DEFAULT NULL,
  2362. `start_date` datetime DEFAULT NULL,
  2363. `mantance_year_number` int(16) DEFAULT NULL,
  2364. `ne_type` varchar(64) DEFAULT NULL,
  2365. `creator` varchar(64) DEFAULT NULL,
  2366. `create_time` datetime DEFAULT NULL,
  2367. `modifier` varchar(64) DEFAULT NULL,
  2368. `modify_time` datetime DEFAULT NULL,
  2369. `time_stamp` datetime DEFAULT NULL,
  2370. `stateflag` mediumtext,
  2371. `ruuid` varchar(128) NOT NULL,
  2372. `data_type` varchar(50) DEFAULT NULL,
  2373. `login_action` text,
  2374. `localize_flag` varchar(32) DEFAULT NULL,
  2375. `current_stat` varchar(32) DEFAULT NULL,
  2376. `contract` varchar(64) DEFAULT NULL,
  2377. `emergency_flag` varchar(32) DEFAULT NULL,
  2378. `monitor_flag` varchar(32) DEFAULT NULL,
  2379. `development_language` varchar(32) DEFAULT NULL,
  2380. `app_type` varchar(64) DEFAULT NULL,
  2381. `contract_money` varchar(32) DEFAULT NULL,
  2382. `unified_login` varchar(12) DEFAULT NULL COMMENT '统一登录:0:以接入统一桌面,1:未接入统一桌面',
  2383. `img_url` varchar(50) DEFAULT NULL,
  2384. `dataType` text,
  2385. `on_line` mediumtext,
  2386. `stateflag1` varchar(20) DEFAULT NULL COMMENT '应用状态',
  2387. `PRIORITY1` varchar(20) DEFAULT NULL COMMENT '重要程度',
  2388. `app_type_name` varchar(20) DEFAULT NULL COMMENT '分类',
  2389. `net_name` varchar(20) DEFAULT NULL COMMENT '网系',
  2390. `IND_VALUE_Network_Cpurate` decimal(20 ,6) DEFAULT NULL comment 'cpu利用率(原始)',
  2391. `IND_VALUE_Network_Cpurate_High` decimal(16 ,2) DEFAULT NULL comment 'CPU利用率峰值(原始)',
  2392. `IND_VALUE_Network_Memrate` decimal(20 ,6) DEFAULT NULL comment '内存利用率(原始)',
  2393. `IND_VALUE_Network_Memrate_High` decimal(16 ,2) DEFAULT NULL comment '内存利用率峰值(原始)',
  2394. `IND_VALUE_HOST_DISK_TOTAL` decimal(38 ,4) DEFAULT NULL comment '磁盘总大小(原始)',
  2395. `IND_VALUE_HOST_DISK_USED` decimal(38 ,4) DEFAULT NULL comment '已使用磁盘大小(原始)',
  2396. `IND_VALUE_HOST_DISK_UTILIZATION` decimal(16 ,4) DEFAULT NULL comment '磁盘利用率峰值(原始)',
  2397. `Band_widthrate` decimal(38,4) DEFAULT NULL COMMENT '实时带宽利用率',
  2398. `Bandwidthrate_High` decimal(38,4) DEFAULT NULL COMMENT '带宽峰值用率',
  2399. `Network_delay` decimal(38,4) DEFAULT NULL COMMENT '网络时延',
  2400. `Network_flow` decimal(38,4) DEFAULT NULL COMMENT '端口流量',
  2401. `Network_PacketErrorrate` decimal(38,4) DEFAULT NULL COMMENT '丢包率',
  2402. `Network_PacketLossrate` decimal(38,4) DEFAULT NULL COMMENT '错包率',
  2403. `Write_rate` decimal(38,4) DEFAULT NULL COMMENT '读写速率',
  2404. `network_Ifinrate` decimal(38,4) DEFAULT NULL COMMENT '下行利用率',
  2405. `network_Ifortrate` decimal(38,4) DEFAULT NULL COMMENT '上行利用率',
  2406. `Device_total` decimal(38,4) DEFAULT NULL COMMENT '设备总量',
  2407. `Device_used` decimal(38,4) DEFAULT NULL COMMENT '设备已用容量',
  2408. `Device_UTILIZATION` decimal(38,4) DEFAULT NULL COMMENT '资源利用率'
  2409. )ENGINE = InnoDB DEFAULT CHARSET = utf8;
  2410. insert into bi_app_resource_group_by_time
  2411. select
  2412. 'HOUR' as dtype,
  2413. date_format(b.CREATE_TIME,'%Y%m%d%H') as thedvalue,
  2414. date_format(b.CREATE_TIME,'%H') as dhour,
  2415. a.*,
  2416. case a.stateflag when 0 then '已应用' else '未应用' end as stateflag1,
  2417. case a.PRIORITY WHEN 'low' then '一般应用' when 'important' then '重要应用' when 'high' then '核心应用' else '未知' end as PRIORITY1,
  2418. d.name as app_type_name,
  2419. e.net_name as net_name,
  2420. avg(b.IND_VALUE_Network_Cpurate) as IND_VALUE_Network_Cpurate,max(b.IND_VALUE_Network_Cpurate_High) as IND_VALUE_Network_Cpurate_High,
  2421. avg(IND_VALUE_Network_Memrate) as IND_VALUE_Network_Memrate,max(IND_VALUE_Network_Memrate_High) as IND_VALUE_Network_Memrate_High,
  2422. 0.0 as IND_VALUE_HOST_DISK_TOTAL, 0.0 as IND_VALUE_HOST_DISK_USED,0.0 as IND_VALUE_HOST_DISK_UTILIZATION,
  2423. rand(10) * 100 as Band_widthrate,
  2424. case when rand(10) * 100 + rand(10) * 10 > 100 then 100 else rand(10) * 100 + rand(10) * 10 end as Bandwidthrate_High,
  2425. rand() * 100 as Network_delay,
  2426. rand() * 10000 as Network_flow,
  2427. rand() as Network_PacketErrorrate,
  2428. rand() as Network_PacketLossrate,
  2429. rand() * 10000 as Write_rate,
  2430. rand() as network_Ifinrate,
  2431. rand() as network_Ifortrate,
  2432. 0.0 * rand(20) * 10 as Device_total,
  2433. 0.0 * rand(20) * 10 as Device_used,
  2434. 0.0 as Device_UTILIZATION
  2435. from itm_app a
  2436. inner join (select * from bi_itm_hardware_resources where servicename !='') c
  2437. on a.ITM_APP_NAME = c.servicename
  2438. -- inner join bi_itm_hardware_resources f
  2439. -- on a.ruuid = c.relatedappid
  2440. inner join app_network_stat b
  2441. on c.itm_hardware_resources_id = b.INT_ID
  2442. inner JOIN m_com_dict d on a.app_type=d.value
  2443. inner JOIN itm_organ_net e on e.NET_ID = a.ITM_NETGROUP_ID
  2444. GROUP BY a.ITM_APP_NAME,date_format(b.CREATE_TIME,'%Y%m%d%H'),date_format(b.CREATE_TIME,'%H'),net_name
  2445. UNION ALL
  2446. select
  2447. 'HOUR' as dtype,
  2448. date_format(b.CREATE_TIME,'%Y%m%d%H') as thedvalue,
  2449. date_format(b.CREATE_TIME,'%H') as dhour,
  2450. a.*,
  2451. case a.stateflag when 0 then '已应用' else '未应用' end as stateflag1,
  2452. case a.PRIORITY WHEN 'low' then '一般应用' when 'important' then '重要应用' when 'high' then '核心应用' else '未知' end as PRIORITY1,
  2453. d.name as app_type_name,
  2454. e.net_name as net_name,
  2455. avg(b.IND_VALUE_Network_Cpurate) as IND_VALUE_Network_Cpurate,max(b.IND_VALUE_Network_Cpurate_High) as IND_VALUE_Network_Cpurate_High,
  2456. avg(IND_VALUE_Network_Memrate) as IND_VALUE_Network_Memrate,max(IND_VALUE_Network_Memrate_High) as IND_VALUE_Network_Memrate_High,
  2457. 0.0 as IND_VALUE_HOST_DISK_TOTAL, 0.0 as IND_VALUE_HOST_DISK_USED,0.0 as IND_VALUE_HOST_DISK_UTILIZATION,
  2458. rand(10) * 100 as Band_widthrate,
  2459. case when rand(10) * 100 + rand(10) * 10 > 100 then 100 else rand(10) * 100 + rand(10) * 10 end as Bandwidthrate_High,
  2460. rand() * 100 as Network_delay,
  2461. rand() * 10000 as Network_flow,
  2462. rand() as Network_PacketErrorrate,
  2463. rand() as Network_PacketLossrate,
  2464. rand() * 10000 as Write_rate,
  2465. rand() as network_Ifinrate,
  2466. rand() as network_Ifortrate,
  2467. 0.0 * rand(20) * 10 as Device_total,
  2468. 0.0 * rand(20) * 10 as Device_used,
  2469. 0.0 as Device_UTILIZATION
  2470. from itm_app a
  2471. inner join (select * from bi_itm_hardware_resources where servicename = '') c
  2472. on a.ruuid = c.relatedappid
  2473. -- inner join bi_itm_hardware_resources f
  2474. -- on a.ruuid = c.relatedappid
  2475. inner join app_network_stat b
  2476. on c.itm_hardware_resources_id = b.INT_ID
  2477. inner JOIN m_com_dict d on a.app_type=d.value
  2478. inner JOIN itm_organ_net e on e.NET_ID = a.ITM_NETGROUP_ID
  2479. GROUP BY a.ITM_APP_NAME,date_format(b.CREATE_TIME,'%Y%m%d%H'),date_format(b.CREATE_TIME,'%H'),net_name
  2480. union all
  2481. select
  2482. 'DAY' as dtype,
  2483. date_format(b.CREATE_TIME,'%Y%m%d') as thedvalue,
  2484. date_format(b.CREATE_TIME,'%H') as dhour,
  2485. a.*,
  2486. case a.stateflag when 0 then '已应用' else '未应用' end as stateflag1,
  2487. case a.PRIORITY WHEN 'low' then '一般应用' when 'important' then '重要应用' when 'high' then '核心应用' else '未知' end as PRIORITY1,
  2488. d.name as app_type_name,
  2489. e.net_name as net_name,
  2490. avg(b.IND_VALUE_Network_Cpurate) as IND_VALUE_Network_Cpurate,max(b.IND_VALUE_Network_Cpurate_High) as IND_VALUE_Network_Cpurate_High,
  2491. avg(IND_VALUE_Network_Memrate) as IND_VALUE_Network_Memrate,max(IND_VALUE_Network_Memrate_High) as IND_VALUE_Network_Memrate_High,
  2492. 0.0 as IND_VALUE_HOST_DISK_TOTAL, 0.0 as IND_VALUE_HOST_DISK_USED,0.0 as IND_VALUE_HOST_DISK_UTILIZATION,
  2493. rand(10) * 100 as Band_widthrate,
  2494. case when rand(10) * 100 + rand(10) * 10 > 100 then 100 else rand(10) * 100 + rand(10) * 10 end as Bandwidthrate_High,
  2495. rand() * 100 as Network_delay,
  2496. rand() * 10000 as Network_flow,
  2497. rand() as Network_PacketErrorrate,
  2498. rand() as Network_PacketLossrate,
  2499. rand() * 10000 as Write_rate,
  2500. rand() as network_Ifinrate,
  2501. rand() as network_Ifortrate,
  2502. 0.0 * rand(20) * 10 as Device_total,
  2503. 0.0 * rand(20) * 10 as Device_used,
  2504. 0.0 as Device_UTILIZATION
  2505. from itm_app a
  2506. inner join (select * from bi_itm_hardware_resources where servicename !='') c
  2507. on a.ITM_APP_NAME = c.servicename
  2508. inner join app_network_stat b
  2509. on c.itm_hardware_resources_id = b.INT_ID
  2510. LEFT JOIN m_com_dict d on a.app_type=d.value
  2511. LEFT JOIN itm_organ_net e on e.NET_ID = a.ITM_NETGROUP_ID
  2512. WHERE d.dict_index='app_type'
  2513. GROUP BY a.ITM_APP_NAME,date_format(b.CREATE_TIME,'%Y%m%d'),date_format(b.CREATE_TIME,'%H')
  2514. union all
  2515. select
  2516. 'DAY' as dtype,
  2517. date_format(b.CREATE_TIME,'%Y%m%d') as thedvalue,
  2518. date_format(b.CREATE_TIME,'%H') as dhour,
  2519. a.*,
  2520. case a.stateflag when 0 then '已应用' else '未应用' end as stateflag1,
  2521. case a.PRIORITY WHEN 'low' then '一般应用' when 'important' then '重要应用' when 'high' then '核心应用' else '未知' end as PRIORITY1,
  2522. d.name as app_type_name,
  2523. e.net_name as net_name,
  2524. avg(b.IND_VALUE_Network_Cpurate) as IND_VALUE_Network_Cpurate,max(b.IND_VALUE_Network_Cpurate_High) as IND_VALUE_Network_Cpurate_High,
  2525. avg(IND_VALUE_Network_Memrate) as IND_VALUE_Network_Memrate,max(IND_VALUE_Network_Memrate_High) as IND_VALUE_Network_Memrate_High,
  2526. 0.0 as IND_VALUE_HOST_DISK_TOTAL, 0.0 as IND_VALUE_HOST_DISK_USED,0.0 as IND_VALUE_HOST_DISK_UTILIZATION,
  2527. rand(10) * 100 as Band_widthrate,
  2528. case when rand(10) * 100 + rand(10) * 10 > 100 then 100 else rand(10) * 100 + rand(10) * 10 end as Bandwidthrate_High,
  2529. rand() * 100 as Network_delay,
  2530. rand() * 10000 as Network_flow,
  2531. rand() as Network_PacketErrorrate,
  2532. rand() as Network_PacketLossrate,
  2533. rand() * 10000 as Write_rate,
  2534. rand() as network_Ifinrate,
  2535. rand() as network_Ifortrate,
  2536. 0.0 * rand(20) * 10 as Device_total,
  2537. 0.0 * rand(20) * 10 as Device_used,
  2538. 0.0 as Device_UTILIZATION
  2539. from itm_app a
  2540. inner join (select * from bi_itm_hardware_resources where servicename = '') c
  2541. on a.ruuid = c.relatedappid
  2542. -- inner join bi_itm_hardware_resources f
  2543. -- on a.ruuid = c.relatedappid
  2544. inner join app_network_stat b
  2545. on c.itm_hardware_resources_id = b.INT_ID
  2546. inner JOIN m_com_dict d on a.app_type=d.value
  2547. inner JOIN itm_organ_net e on e.NET_ID = a.ITM_NETGROUP_ID
  2548. GROUP BY a.ITM_APP_NAME,date_format(b.CREATE_TIME,'%Y%m%d'),date_format(b.CREATE_TIME,'%H'),net_name
  2549. union all
  2550. select
  2551. 'WEEK' as dtype,
  2552. date_format(b.CREATE_TIME,'%Y%u') as thedvalue,
  2553. date_format(b.CREATE_TIME,'%H') as dhour,
  2554. a.*,
  2555. case a.stateflag when 0 then '已应用' else '未应用' end as stateflag1,
  2556. case a.PRIORITY WHEN 'low' then '一般应用' when 'important' then '重要应用' when 'high' then '核心应用' else '未知' end as PRIORITY1,
  2557. d.name as app_type_name,
  2558. e.net_name as net_name,
  2559. avg(b.IND_VALUE_Network_Cpurate) as IND_VALUE_Network_Cpurate,max(b.IND_VALUE_Network_Cpurate_High) as IND_VALUE_Network_Cpurate_High,
  2560. avg(IND_VALUE_Network_Memrate) as IND_VALUE_Network_Memrate,max(IND_VALUE_Network_Memrate_High) as IND_VALUE_Network_Memrate_High,
  2561. 0.0 as IND_VALUE_HOST_DISK_TOTAL, 0.0 as IND_VALUE_HOST_DISK_USED,0.0 as IND_VALUE_HOST_DISK_UTILIZATION,
  2562. rand(10) * 100 as Band_widthrate,
  2563. case when rand(10) * 100 + rand(10) * 10 > 100 then 100 else rand(10) * 100 + rand(10) * 10 end as Bandwidthrate_High,
  2564. rand() * 100 as Network_delay,
  2565. rand() * 10000 as Network_flow,
  2566. rand() as Network_PacketErrorrate,
  2567. rand() as Network_PacketLossrate,
  2568. rand() * 10000 as Write_rate,
  2569. rand() as network_Ifinrate,
  2570. rand() as network_Ifortrate,
  2571. 0.0 * rand(20) * 10 as Device_total,
  2572. 0.0 * rand(20) * 10 as Device_used,
  2573. 0.0 as Device_UTILIZATION
  2574. from itm_app a
  2575. inner join (select * from bi_itm_hardware_resources where servicename != '') c
  2576. on a.ITM_APP_NAME = c.servicename
  2577. inner join app_network_stat b
  2578. on c.itm_hardware_resources_id = b.INT_ID
  2579. LEFT JOIN m_com_dict d on a.app_type=d.value
  2580. LEFT JOIN itm_organ_net e on e.NET_ID = a.ITM_NETGROUP_ID
  2581. WHERE d.dict_index='app_type'
  2582. GROUP BY a.ITM_APP_NAME,date_format(b.CREATE_TIME,'%Y%u'),date_format(b.CREATE_TIME,'%H')
  2583. union all
  2584. select
  2585. 'WEEK' as dtype,
  2586. date_format(b.CREATE_TIME,'%Y%u') as thedvalue,
  2587. date_format(b.CREATE_TIME,'%H') as dhour,
  2588. a.*,
  2589. case a.stateflag when 0 then '已应用' else '未应用' end as stateflag1,
  2590. case a.PRIORITY WHEN 'low' then '一般应用' when 'important' then '重要应用' when 'high' then '核心应用' else '未知' end as PRIORITY1,
  2591. d.name as app_type_name,
  2592. e.net_name as net_name,
  2593. avg(b.IND_VALUE_Network_Cpurate) as IND_VALUE_Network_Cpurate,max(b.IND_VALUE_Network_Cpurate_High) as IND_VALUE_Network_Cpurate_High,
  2594. avg(IND_VALUE_Network_Memrate) as IND_VALUE_Network_Memrate,max(IND_VALUE_Network_Memrate_High) as IND_VALUE_Network_Memrate_High,
  2595. 0.0 as IND_VALUE_HOST_DISK_TOTAL, 0.0 as IND_VALUE_HOST_DISK_USED,0.0 as IND_VALUE_HOST_DISK_UTILIZATION,
  2596. rand(10) * 100 as Band_widthrate,
  2597. case when rand(10) * 100 + rand(10) * 10 > 100 then 100 else rand(10) * 100 + rand(10) * 10 end as Bandwidthrate_High,
  2598. rand() * 100 as Network_delay,
  2599. rand() * 10000 as Network_flow,
  2600. rand() as Network_PacketErrorrate,
  2601. rand() as Network_PacketLossrate,
  2602. rand() * 10000 as Write_rate,
  2603. rand() as network_Ifinrate,
  2604. rand() as network_Ifortrate,
  2605. 0.0 * rand(20) * 10 as Device_total,
  2606. 0.0 * rand(20) * 10 as Device_used,
  2607. 0.0 as Device_UTILIZATION
  2608. from itm_app a
  2609. inner join (select * from bi_itm_hardware_resources where servicename = '') c
  2610. on a.ruuid = c.relatedappid
  2611. inner join app_network_stat b
  2612. on c.itm_hardware_resources_id = b.INT_ID
  2613. LEFT JOIN m_com_dict d on a.app_type=d.value
  2614. LEFT JOIN itm_organ_net e on e.NET_ID = a.ITM_NETGROUP_ID
  2615. WHERE d.dict_index='app_type'
  2616. GROUP BY a.ITM_APP_NAME,date_format(b.CREATE_TIME,'%Y%u'),date_format(b.CREATE_TIME,'%H')
  2617. union all
  2618. select
  2619. 'MONTH' as dtype,
  2620. date_format(b.CREATE_TIME,'%Y%m') as thedvalue,
  2621. date_format(b.CREATE_TIME,'%H') as dhour,
  2622. a.*,
  2623. case a.stateflag when 0 then '已应用' else '未应用' end as stateflag1,
  2624. case a.PRIORITY WHEN 'low' then '一般应用' when 'important' then '重要应用' when 'high' then '核心应用' else '未知' end as PRIORITY1,
  2625. d.name as app_type_name,
  2626. e.net_name as net_name,
  2627. avg(b.IND_VALUE_Network_Cpurate) as IND_VALUE_Network_Cpurate,max(b.IND_VALUE_Network_Cpurate_High) as IND_VALUE_Network_Cpurate_High,
  2628. avg(IND_VALUE_Network_Memrate) as IND_VALUE_Network_Memrate,max(IND_VALUE_Network_Memrate_High) as IND_VALUE_Network_Memrate_High,
  2629. 0.0 as IND_VALUE_HOST_DISK_TOTAL, 0.0 as IND_VALUE_HOST_DISK_USED,0.0 as IND_VALUE_HOST_DISK_UTILIZATION,
  2630. rand(10) * 100 as Band_widthrate,
  2631. case when rand(10) * 100 + rand(10) * 10 > 100 then 100 else rand(10) * 100 + rand(10) * 10 end as Bandwidthrate_High,
  2632. rand() * 100 as Network_delay,
  2633. rand() * 10000 as Network_flow,
  2634. rand() as Network_PacketErrorrate,
  2635. rand() as Network_PacketLossrate,
  2636. rand() * 10000 as Write_rate,
  2637. rand() as network_Ifinrate,
  2638. rand() as network_Ifortrate,
  2639. 0.0 * rand(20) * 10 as Device_total,
  2640. 0.0 * rand(20) * 10 as Device_used,
  2641. 0.0 as Device_UTILIZATION
  2642. from itm_app a
  2643. inner join (select * from bi_itm_hardware_resources where servicename != '') c
  2644. on a.ITM_APP_NAME = c.servicename
  2645. inner join app_network_stat b
  2646. on c.itm_hardware_resources_id = b.INT_ID
  2647. LEFT JOIN m_com_dict d on a.app_type=d.value
  2648. LEFT JOIN itm_organ_net e on e.NET_ID = a.ITM_NETGROUP_ID
  2649. WHERE d.dict_index='app_type'
  2650. GROUP BY a.ITM_APP_NAME,date_format(b.CREATE_TIME,'%Y%m'),date_format(b.CREATE_TIME,'%H')
  2651. union all
  2652. select
  2653. 'MONTH' as dtype,
  2654. date_format(b.CREATE_TIME,'%Y%m') as thedvalue,
  2655. date_format(b.CREATE_TIME,'%H') as dhour,
  2656. a.*,
  2657. case a.stateflag when 0 then '已应用' else '未应用' end as stateflag1,
  2658. case a.PRIORITY WHEN 'low' then '一般应用' when 'important' then '重要应用' when 'high' then '核心应用' else '未知' end as PRIORITY1,
  2659. d.name as app_type_name,
  2660. e.net_name as net_name,
  2661. avg(b.IND_VALUE_Network_Cpurate) as IND_VALUE_Network_Cpurate,max(b.IND_VALUE_Network_Cpurate_High) as IND_VALUE_Network_Cpurate_High,
  2662. avg(IND_VALUE_Network_Memrate) as IND_VALUE_Network_Memrate,max(IND_VALUE_Network_Memrate_High) as IND_VALUE_Network_Memrate_High,
  2663. 0.0 as IND_VALUE_HOST_DISK_TOTAL, 0.0 as IND_VALUE_HOST_DISK_USED,0.0 as IND_VALUE_HOST_DISK_UTILIZATION,
  2664. rand(10) * 100 as Band_widthrate,
  2665. case when rand(10) * 100 + rand(10) * 10 > 100 then 100 else rand(10) * 100 + rand(10) * 10 end as Bandwidthrate_High,
  2666. rand() * 100 as Network_delay,
  2667. rand() * 10000 as Network_flow,
  2668. rand() as Network_PacketErrorrate,
  2669. rand() as Network_PacketLossrate,
  2670. rand() * 10000 as Write_rate,
  2671. rand() as network_Ifinrate,
  2672. rand() as network_Ifortrate,
  2673. 0.0 * rand(20) * 10 as Device_total,
  2674. 0.0 * rand(20) * 10 as Device_used,
  2675. 0.0 as Device_UTILIZATION
  2676. from itm_app a
  2677. inner join (select * from bi_itm_hardware_resources where servicename = '') c
  2678. on a.ruuid = c.relatedappid
  2679. inner join app_network_stat b
  2680. on c.itm_hardware_resources_id = b.INT_ID
  2681. LEFT JOIN m_com_dict d on a.app_type=d.value
  2682. LEFT JOIN itm_organ_net e on e.NET_ID = a.ITM_NETGROUP_ID
  2683. WHERE d.dict_index='app_type'
  2684. GROUP BY a.ITM_APP_NAME,date_format(b.CREATE_TIME,'%Y%m'),date_format(b.CREATE_TIME,'%H')
  2685. union all
  2686. select
  2687. 'YEAR' as dtype,
  2688. date_format(b.CREATE_TIME,'%Y') as thedvalue,
  2689. date_format(b.CREATE_TIME,'%H') as dhour,
  2690. a.*,
  2691. case a.stateflag when 0 then '已应用' else '未应用' end as stateflag1,
  2692. case a.PRIORITY WHEN 'low' then '一般应用' when 'important' then '重要应用' when 'high' then '核心应用' else '未知' end as PRIORITY1,
  2693. d.name as app_type_name,
  2694. e.net_name as net_name,
  2695. avg(b.IND_VALUE_Network_Cpurate) as IND_VALUE_Network_Cpurate,max(b.IND_VALUE_Network_Cpurate_High) as IND_VALUE_Network_Cpurate_High,
  2696. avg(IND_VALUE_Network_Memrate) as IND_VALUE_Network_Memrate,max(IND_VALUE_Network_Memrate_High) as IND_VALUE_Network_Memrate_High,
  2697. 0.0 as IND_VALUE_HOST_DISK_TOTAL, 0.0 as IND_VALUE_HOST_DISK_USED,0.0 as IND_VALUE_HOST_DISK_UTILIZATION,
  2698. rand(10) * 100 as Band_widthrate,
  2699. case when rand(10) * 100 + rand(10) * 10 > 100 then 100 else rand(10) * 100 + rand(10) * 10 end as Bandwidthrate_High,
  2700. rand() * 100 as Network_delay,
  2701. rand() * 10000 as Network_flow,
  2702. rand() as Network_PacketErrorrate,
  2703. rand() as Network_PacketLossrate,
  2704. rand() * 10000 as Write_rate,
  2705. rand() as network_Ifinrate,
  2706. rand() as network_Ifortrate,
  2707. 0.0 * rand(20) * 10 as Device_total,
  2708. 0.0 * rand(20) * 10 as Device_used,
  2709. 0.0 as Device_UTILIZATION
  2710. from itm_app a
  2711. inner join (select * from bi_itm_hardware_resources where servicename != '') c
  2712. on a.ITM_APP_NAME = c.servicename
  2713. inner join app_network_stat b
  2714. on c.itm_hardware_resources_id = b.INT_ID
  2715. LEFT JOIN m_com_dict d on a.app_type=d.value
  2716. LEFT JOIN itm_organ_net e on e.NET_ID = a.ITM_NETGROUP_ID
  2717. WHERE d.dict_index='app_type'
  2718. GROUP BY a.ITM_APP_NAME,date_format(b.CREATE_TIME,'%Y'),date_format(b.CREATE_TIME,'%H')
  2719. union ALL
  2720. select
  2721. 'YEAR' as dtype,
  2722. date_format(b.CREATE_TIME,'%Y') as thedvalue,
  2723. date_format(b.CREATE_TIME,'%H') as dhour,
  2724. a.*,
  2725. case a.stateflag when 0 then '已应用' else '未应用' end as stateflag1,
  2726. case a.PRIORITY WHEN 'low' then '一般应用' when 'important' then '重要应用' when 'high' then '核心应用' else '未知' end as PRIORITY1,
  2727. d.name as app_type_name,
  2728. e.net_name as net_name,
  2729. avg(b.IND_VALUE_Network_Cpurate) as IND_VALUE_Network_Cpurate,max(b.IND_VALUE_Network_Cpurate_High) as IND_VALUE_Network_Cpurate_High,
  2730. avg(IND_VALUE_Network_Memrate) as IND_VALUE_Network_Memrate,max(IND_VALUE_Network_Memrate_High) as IND_VALUE_Network_Memrate_High,
  2731. 0.0 as IND_VALUE_HOST_DISK_TOTAL, 0.0 as IND_VALUE_HOST_DISK_USED,0.0 as IND_VALUE_HOST_DISK_UTILIZATION,
  2732. rand(10) * 100 as Band_widthrate,
  2733. case when rand(10) * 100 + rand(10) * 10 > 100 then 100 else rand(10) * 100 + rand(10) * 10 end as Bandwidthrate_High,
  2734. rand() * 100 as Network_delay,
  2735. rand() * 10000 as Network_flow,
  2736. rand() as Network_PacketErrorrate,
  2737. rand() as Network_PacketLossrate,
  2738. rand() * 10000 as Write_rate,
  2739. rand() as network_Ifinrate,
  2740. rand() as network_Ifortrate,
  2741. 0.0 * rand(20) * 10 as Device_total,
  2742. 0.0 * rand(20) * 10 as Device_used,
  2743. 0.0 as Device_UTILIZATION
  2744. from itm_app a
  2745. inner join (select * from bi_itm_hardware_resources where servicename = '') c
  2746. on a.ruuid = c.relatedappid
  2747. inner join app_network_stat b
  2748. on c.itm_hardware_resources_id = b.INT_ID
  2749. LEFT JOIN m_com_dict d on a.app_type=d.value
  2750. LEFT JOIN itm_organ_net e on e.NET_ID = a.ITM_NETGROUP_ID
  2751. WHERE d.dict_index='app_type'
  2752. GROUP BY a.ITM_APP_NAME,date_format(b.CREATE_TIME,'%Y'),date_format(b.CREATE_TIME,'%H');
  2753. DROP TABLE IF EXISTS `bi_app_access_stat`;
  2754. CREATE TABLE `bi_app_access_stat` (
  2755. `dtype` varchar(5) NOT NULL DEFAULT '' COMMENT '日期类型',
  2756. `thedvalue` varchar(20) DEFAULT NULL COMMENT '日期',
  2757. `NET_ID` varchar(64) DEFAULT NULL COMMENT '网系ID',
  2758. `NET_NAME` varchar(64) DEFAULT NULL COMMENT '网系名称',
  2759. `ORGAN_ID` varchar(100) DEFAULT NULL COMMENT '区域ID/数据来源',
  2760. `ORGAN_NAME` varchar(100) DEFAULT NULL COMMENT '区域名称',
  2761. `app_id` varchar(64) DEFAULT NULL COMMENT '应用ID',
  2762. `app_name` varchar(255) DEFAULT NULL COMMENT '应用名称',
  2763. `visit_count` decimal(20,10) DEFAULT NULL COMMENT '访问数',
  2764. `operate_count` decimal(20,10) DEFAULT NULL COMMENT '操作量',
  2765. `priority` varchar(10) DEFAULT NULL COMMENT '应用等级:核心-high;重要-important;一般-low',
  2766. `app_type` varchar(255) DEFAULT NULL COMMENT '应用分类'
  2767. ) ENGINE = InnoDB DEFAULT CHARSET = utf8;
  2768. insert into bi_app_access_stat
  2769. SELECT
  2770. 'HOUR' AS dtype,
  2771. DATE_FORMAT(A.time_mark,'%Y%m%d%H') as thedvalue,
  2772. B.ITM_NETGROUP_ID AS NET_ID,
  2773. C.NAME AS net_name,
  2774. A.ORGAN_ID AS ORGAN_ID,
  2775. D.short_name AS ORGAN_name,
  2776. A.app_id as app_id,
  2777. B.ITM_APP_NAME AS app_name,
  2778. sum(A.visit_count) as visit_count,
  2779. sum(A.operate_count) as operate_count ,
  2780. CASE
  2781. B.PRIORITY
  2782. WHEN 'low' THEN
  2783. '一般应用'
  2784. WHEN 'important' THEN
  2785. '重要应用'
  2786. WHEN 'high' THEN
  2787. '核心应用' ELSE '未知'
  2788. END AS PRIORITY,
  2789. F.NAME
  2790. FROM app_visit_log_region as A
  2791. LEFT JOIN itm_app B on A.app_id=B.itm_app_id
  2792. LEFT JOIN ( SELECT VALUE, NAME FROM m_com_dict WHERE dict_index = 'itm_resources_netcode' ) C ON C.VALUE = B.ITM_NETGROUP_ID
  2793. LEFT JOIN pub_organ D ON D.id = A.ORGAN_ID
  2794. LEFT JOIN ( SELECT temp1.ITM_APP_ID, temp2.NAME FROM itm_app temp1 LEFT JOIN m_com_dict temp2 ON temp1.app_type = temp2.VALUE ) AS F ON A.app_id = F.itm_app_id
  2795. GROUP BY
  2796. A.app_id,
  2797. A.ORGAN_ID,
  2798. B.ITM_NETGROUP_ID,
  2799. B.ITM_APP_NAME,
  2800. C.NAME,
  2801. D.short_name,
  2802. B.priority,
  2803. F.NAME,
  2804. B.PRIORITY,
  2805. A.time_mark,
  2806. DATE_FORMAT(A.time_mark,'%Y%m%d%H');
  2807. insert into bi_app_access_stat
  2808. SELECT
  2809. 'DAY' AS dtype,
  2810. substring(thedvalue,1,8) AS thedvalue,
  2811. NET_ID,
  2812. net_name,
  2813. ORGAN_ID,
  2814. ORGAN_name,
  2815. app_id,
  2816. app_name,
  2817. sum(visit_count) as visit_count,
  2818. sum(operate_count) as operate_count ,
  2819. CASE
  2820. PRIORITY
  2821. WHEN 'low' THEN
  2822. '一般应用'
  2823. WHEN 'important' THEN
  2824. '重要应用'
  2825. WHEN 'high' THEN
  2826. '核心应用' ELSE '未知'
  2827. END AS PRIORITY,
  2828. app_type
  2829. FROM bi_app_access_stat WHERE dtype = 'HOUR'
  2830. GROUP BY
  2831. dtype,
  2832. thedvalue,
  2833. NET_ID,
  2834. net_name,
  2835. ORGAN_ID,
  2836. ORGAN_name,
  2837. app_id,
  2838. app_name,
  2839. priority,
  2840. app_type,
  2841. substring(thedvalue,1,8);
  2842. insert into bi_app_access_stat
  2843. SELECT
  2844. 'MONTH' AS dtype,
  2845. substring(thedvalue,1,6) AS thedvalue,
  2846. NET_ID,
  2847. net_name,
  2848. ORGAN_ID,
  2849. ORGAN_name,
  2850. app_id,
  2851. app_name,
  2852. sum(visit_count) as visit_count,
  2853. sum(operate_count) as operate_count ,
  2854. CASE
  2855. PRIORITY
  2856. WHEN 'low' THEN
  2857. '一般应用'
  2858. WHEN 'important' THEN
  2859. '重要应用'
  2860. WHEN 'high' THEN
  2861. '核心应用' ELSE '未知'
  2862. END AS PRIORITY,
  2863. app_type
  2864. FROM bi_app_access_stat WHERE dtype = 'DAY'
  2865. GROUP BY
  2866. dtype,
  2867. thedvalue,
  2868. NET_ID,
  2869. net_name,
  2870. ORGAN_ID,
  2871. ORGAN_name,
  2872. app_id,
  2873. app_name,
  2874. priority,
  2875. app_type,
  2876. substring(thedvalue,1,6);
  2877. insert into bi_app_access_stat
  2878. SELECT
  2879. 'YEAR' AS dtype,
  2880. substring(thedvalue,1,4) AS thedvalue,
  2881. NET_ID,
  2882. net_name,
  2883. ORGAN_ID,
  2884. ORGAN_name,
  2885. app_id,
  2886. app_name,
  2887. sum(visit_count) as visit_count,
  2888. sum(operate_count) as operate_count ,
  2889. CASE
  2890. PRIORITY
  2891. WHEN 'low' THEN
  2892. '一般应用'
  2893. WHEN 'important' THEN
  2894. '重要应用'
  2895. WHEN 'high' THEN
  2896. '核心应用' ELSE '未知'
  2897. END AS PRIORITY,
  2898. app_type
  2899. FROM bi_app_access_stat WHERE dtype = 'MONTH'
  2900. GROUP BY
  2901. dtype,
  2902. thedvalue,
  2903. NET_ID,
  2904. net_name,
  2905. ORGAN_ID,
  2906. ORGAN_name,
  2907. app_id,
  2908. app_name,
  2909. priority,
  2910. app_type,
  2911. substring(thedvalue,1,4)
  2912. -- 响应时间趋势
  2913. DROP TABLE IF EXISTS `bi_app_response_time_stat`;
  2914. CREATE TABLE `bi_app_response_time_stat` (
  2915. `dtype` varchar(5) NOT NULL DEFAULT '' COMMENT '日期类型',
  2916. `thedvalue` varchar(20) DEFAULT NULL COMMENT '日期',
  2917. `dhour` varchar(15) DEFAULT NULL COMMENT '小时',
  2918. `NET_ID` varchar(64) DEFAULT NULL COMMENT '网系ID',
  2919. `NET_NAME` varchar(64) DEFAULT NULL COMMENT '网系名称',
  2920. `ORGAN_ID` varchar(100) DEFAULT NULL COMMENT '区域ID/数据来源',
  2921. `ORGAN_NAME` varchar(100) DEFAULT NULL COMMENT '区域名称',
  2922. `app_id` varchar(64) DEFAULT NULL COMMENT '应用ID',
  2923. `app_name` varchar(255) DEFAULT NULL COMMENT '应用名称',
  2924. `response_time` decimal(20,10) DEFAULT NULL COMMENT '响应时间',
  2925. `priority` varchar(10) DEFAULT NULL COMMENT '应用等级:核心-high;重要-important;一般-low',
  2926. `app_type` varchar(255) DEFAULT NULL COMMENT '应用分类'
  2927. ) ENGINE = InnoDB DEFAULT CHARSET = utf8;
  2928. insert into bi_app_response_time_stat
  2929. select
  2930. 'HOUR' as dtype,
  2931. date_format(a.CREATE_TIME,'%Y%m%d%H') as thedvalue,
  2932. date_format(a.CREATE_TIME,'%H') as dhour,
  2933. b.ITM_NETGROUP_ID as NET_ID,
  2934. d.name as NET_NAME,
  2935. a.ORGAN_ID as ORGAN_ID,
  2936. e.`SHORT_NAME` as organ_name,
  2937. a.app_id as app_id,
  2938. b.ITM_APP_NAME as app_name,
  2939. avg(a.resp_time) as response_time,
  2940. case b.PRIORITY WHEN 'low' then '一般应用' when 'important' then '重要应用' when 'high' then '核心应用' else '未知' end as priority,
  2941. e.name as app_type
  2942. from app_app_detail_stat a
  2943. LEFT JOIN itm_app b on a.app_id =b.ITM_APP_ID
  2944. LEFT JOIN itm_organ_net c on c.NET_ID = a.net_id
  2945. inner JOIN (select * from m_com_dict where dict_index = 'app_type') d on b.app_type=d.value
  2946. left join pub_organ e on b.ORGAN_ID = e.`CODE`
  2947. group by
  2948. date_format(a.monitortime,'%Y%m%d%H'),date_format(a.monitortime,'%H'),
  2949. b.PRIORITY,
  2950. d.name,c.net_name,a.id ,a.app_id ,a.app_name ,a.ORGAN_ID ,a.net_id,e.`SHORT_NAME`,e.`NAME`;
  2951. insert into bi_app_response_time_stat
  2952. select 'DAY' as dtype,substring(thedvalue,1,8) AS thedvalue,
  2953. dhour, NET_ID, NET_NAME, ORGAN_ID, ORGAN_NAME, app_id, app_name, avg(response_time) as response_time, priority, app_type
  2954. from bi_app_response_time_stat
  2955. where dtype = 'HOUR'
  2956. GROUP BY substring(thedvalue,1,8),dhour, NET_ID, NET_NAME, ORGAN_ID, ORGAN_NAME, app_id, app_name,priority, app_type;
  2957. insert into bi_app_response_time_stat
  2958. select 'MONTH' as dtype,substring(thedvalue,1,6) AS thedvalue,
  2959. dhour, NET_ID, NET_NAME, ORGAN_ID, ORGAN_NAME, app_id, app_name, avg(response_time) as response_time, priority, app_type
  2960. from bi_app_response_time_stat
  2961. where dtype = 'DAY'
  2962. GROUP BY substring(thedvalue,1,6),dhour, NET_ID, NET_NAME, ORGAN_ID, ORGAN_NAME, app_id, app_name,priority, app_type;
  2963. insert into bi_app_response_time_stat
  2964. select 'YEAR' as dtype,substring(thedvalue,1,4) AS thedvalue,
  2965. dhour, NET_ID, NET_NAME, ORGAN_ID, ORGAN_NAME, app_id, app_name, avg(response_time) as response_time, priority, app_type
  2966. from bi_app_response_time_stat
  2967. where dtype = 'MONTH'
  2968. GROUP BY substring(thedvalue,1,4),dhour, NET_ID, NET_NAME, ORGAN_ID, ORGAN_NAME, app_id, app_name,priority, app_type;