CREATE VIEW WANScoreBoard AS
SELECT r.server_addr
,r.probe_addr
,r.rsrcIndex
,r.rsrcName
,r.userId
,ifInOctets=100-100*SUM(CASE a.fieldIndex WHEN 101 THEN (alertDuration*severity/5.0)/(24*3600) ELSE 0 END)
,ifOutOctets=100-100*SUM(CASE a.fieldIndex WHEN 107 THEN (alertDuration*severity/5.0)/(24*3600) ELSE 0 END)
,inboundErrors=100-100*SUM(CASE WHEN a.fieldIndex IN (104,105,106) THEN (alertDuration*severity/5.0)/(24*3600) ELSE 0 END)
,outboundErrors=100-100*SUM(case WHEN a.fieldIndex IN (110,111) THEN (alertDuration*severity/5.0)/(24*3600) ELSE 0 END)
,availability=100-100*SUM(CASE WHEN a.fieldIndex = 1602 THEN (a.alertDuration*1.0)/(24*3600) ELSE 0 END)
FROM ResourceNameWANView 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
GO
GRANT SELECT ON [dbo].[WANScoreBoard] TO [uniadmin]
GO