forked from samyan19/SQL-Scripts
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathDriveStats.ps1
More file actions
47 lines (38 loc) · 1.66 KB
/
DriveStats.ps1
File metadata and controls
47 lines (38 loc) · 1.66 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
Param (
[string]$computername , [string]$InstanceName
)
#####################################################
#
#20140718 - IG - added code to view mountpoints.
#
#####################################################
Add-PSSnapin SqlServerCmdletSnapin100
Add-PSSnapin SqlServerProviderSnapin100
#Import-Module SQLPS -DisableNameChecking
$a = Get-WmiObject Win32_Volume -ComputerName $computername |
Select-Object Name, DriveType,FileSystem,SystemVolume,
@{name='SizeMB';expr={[int]($_.Capacity/1MB)}},
@{name='FreeSpaceMB';expr={[int]($_.FreeSpace/1MB)}},
@{name='PercentFreeSpace';expr={"{0:N2}" -f(($_.Freespace/$_.Capacity)*100)}},
Label | Where-Object {$_.DriveType -eq 3}
foreach ($z in $a | Where-Object {$_.SystemVolume -ne 'True'})
{
$DeviceID = $z.Name.TrimEnd(":\")
$SizeMB = $z.SizeMB
$FreeSpaceMB = $z.FreeSpaceMB
$PercentFreeNow = $z.PercentFreeSpace
$VolumeName = $z.Label
Invoke-Sqlcmd -ServerInstance $InstanceName -Database 'zzSQLServerAdmin' -Query "MERGE [dbo].[tblDriveStats] AS Target
USING (SELECT '$DeviceID', '$SizeMB', '$FreeSpaceMB', '$PercentFreeNow', '$VolumeName' ) AS Source (DeviceID, SizeMB, FreeSpaceMB, PercentFreeNow, VolumeName)
ON Target.DriveLetter = DeviceID
WHEN MATCHED THEN
UPDATE SET
TotalSizeMB = '$SizeMB',
FreeSpaceMB = '$FreeSpaceMB',
PercentFreeNow = '$PercentFreeNow',
VolumeName = '$VolumeName',
LastUpdate = Current_Timestamp
WHEN NOT MATCHED THEN
INSERT (ServerName, LastUpdate, DriveLetter, TotalSizeMB, FreeSpaceMB, PercentFreeWarning, PercentFreeCrit, PercentFreeNow, VolumeName)
VALUES (@@SERVERNAME, Current_Timestamp, '$DeviceID', '$SizeMB', '$FreeSpaceMB', 25, 15, '$PercentFreeNow', '$VolumeName');"
}