CREATE VIEW IPAlertView AS
SELECT r.server_addr
,r.probe_addr
,r.rsrcName
,r.userId
,ipInReceives=CASE a.fieldIndex WHEN 201 THEN 100*SUM(alertDuration*severity/5.0)/(24*3600) ELSE 0 END
,ipInErrors=CASE WHEN a.fieldIndex IN (202,203,205,206) THEN 100*SUM(alertDuration*severity/5.0)/(24*3600) ELSE 0 END
,ipForwDatagrams=CASE WHEN a.fieldIndex=204 THEN 100*SUM(alertDuration*severity/5.0)/(24*3600) ELSE 0 END
,ipInDelivers=case WHEN a.fieldIndex =207 THEN 100*SUM(alertDuration*severity/5.0)/(24*3600) ELSE 0 END
,ipOutErrors=CASE WHEN a.fieldIndex IN (209,210) THEN 100*SUM(alertDuration*severity/5.0)/(24*3600) ELSE 0 END
,ipOutRequest=CASE WHEN a.fieldIndex=208 THEN 100*SUM(alertDuration*severity/5.0)/(24*3600) ELSE 0 END
,unavail=CASE WHEN a.fieldIndex =1601 THEN 100*SUM(a.alertDuration*1.0)/(24*3600) ELSE 0 END
FROM ResourceNameIPView r, AlertView a
WHERE r.server_addr=a.server_addr
AND r.probe_addr=a.probe_addr
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 = 2
GROUP BY r.server_addr
,r.probe_addr
,r.rsrcName
,r.userId
,a.fieldIndex
GO
GRANT SELECT ON [dbo].[IPAlertView] TO [uniadmin]
GO