forked from dsccommunity/SqlServerDsc
-
Notifications
You must be signed in to change notification settings - Fork 0
/
3-RunScriptCompleteExample.ps1
53 lines (44 loc) · 1.23 KB
/
3-RunScriptCompleteExample.ps1
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
48
49
50
51
52
53
<#
.DESCRIPTION
This example uses the Configuration Data to pass the Query Strings fo SqlScriptQuery Resource.
#>
Configuration Example
{
param
(
[Parameter(Mandatory = $true)]
[ValidateNotNullOrEmpty()]
[System.Management.Automation.PSCredential]
$SqlAdministratorCredential
)
Import-DscResource -ModuleName 'SqlServerDsc'
node localhost
{
SqlScriptQuery 'CreateDatabase_ScriptDatabase1'
{
ServerName = $env:COMPUTERNAME
InstanceName = 'DSCTEST'
GetQuery = @'
SELECT Name FROM sys.databases WHERE Name = '$(DatabaseName)' FOR JSON AUTO
'@
TestQuery = @'
if (select count(name) from sys.databases where name = '$(DatabaseName)') = 0
BEGIN
RAISERROR ('Did not find database [$(DatabaseName)]', 16, 1)
END
ELSE
BEGIN
PRINT 'Found database [$(DatabaseName)]'
END
'@
SetQuery = @'
CREATE DATABASE [$(DatabaseName)]
'@
Variable = @(
('DatabaseName={0}' -f 'ScriptDatabase1')
)
QueryTimeout = 30
PsDscRunAsCredential = $SqlAdministratorCredential
}
}
}