
[dbo].[InterfaceAlertView]
CREATE VIEW InterfaceAlertView AS
SELECT r.server_addr
,r.probe_addr
,r.rsrcIndex
,r.rsrcName
,r.userId
,ifInOctets=CASE a.fieldIndex WHEN 101 THEN 100*SUM(alertDuration*severity/5.0)/(24*3600) ELSE 0 END
,ifOutOctets=CASE a.fieldIndex WHEN 107 THEN 100*SUM(alertDuration*severity/5.0)/(24*3600) ELSE 0 END
,inboundErrors=CASE WHEN a.fieldIndex IN (104,105,106) THEN 100*SUM(alertDuration*severity/5.0)/(24*3600) ELSE 0 END
,outboundErrors=case WHEN a.fieldIndex IN (110,111) THEN 100*SUM(alertDuration*severity/5.0)/(24*3600) ELSE 0 END
,unavail=CASE WHEN a.fieldIndex = 1602 THEN 100*SUM(a.alertDuration*1.0)/(24*3600) ELSE 0 END
FROM ResourceNameInterfaceView r, AlertView a
WHERE r.server_addr=a.server_addr
AND r.probe_addr=a.probe_addr
AND r.rsrcIndex=a.rsrcIndex
AND a.severity > 0
AND a.severity <=5
AND r.monitored=1
AND a.IntervalDateTime BETWEEN dateadd(second, -datepart(second, getdate()),
dateadd(minute, -datepart(minute, getdate()),
dateadd(hour, -datepart(hour, getdate()),
dateadd(day, -1, getdate()))))
AND dateadd(second, -datepart(second, getdate()),
dateadd(minute, -datepart(minute, getdate()),
dateadd(hour, -datepart(hour, getdate()),
getdate())))
AND a.fieldIndex/100 = 1
GROUP BY r.server_addr
,r.probe_addr
,r.rsrcIndex
,r.rsrcName
,r.userId
,a.fieldIndex
GO
GRANT SELECT ON [dbo].[InterfaceAlertView] TO [uniadmin]
GO