LocalDb和SMO - 如何选择放置数据库文件的位置?

时间:2013-02-21 09:04:02

标签: powershell smo localdb

我已经开始尝试使用SQL Server 2012功能LocalDb。我正在使用SMO对我创建的实例进行一些PowerShell脚本编写,例如创建数据库。为此,我有这个功能:

Function New-Database {
    Param(
        $server,
        $databaseName
    )
    $serverHandle = New-Object Microsoft.SqlServer.Management.Smo.Server($server)
    if($serverHandle.Databases.Name.Contains($databaseName)) {
        throw "Database $databaseName already exists"
    }

    $databaseHandle = New-Object Microsoft.SqlServer.Management.Smo.Database($serverHandle, $databaseName)
    $databaseHandle.Create()
}

使用LocalDb时,mdf和ldf文件在C:\Users\<username>\中创建。我想覆盖这个,但我没有弄清楚如何。 $databaseHandle对象具有属性PrimaryFilePath,但这是只读的。这似乎应该是死的简单的事情,但我无法找到如何......

解决方案 在下面的答案的带领下,这是我需要的Powershell电话:

    $fileGroup = New-Object Microsoft.SqlServer.Management.Smo.FileGroup($databaseHandle, "PRIMARY")
    $dataFile = New-Object Microsoft.SqlServer.Management.Smo.DataFile($fileGroup, "DataFile", $filePath)
    $fileGroup.Files.Add($dataFile)
    $databaseHandle.FileGroups.Add($fileGroup)

1 个答案:

答案 0 :(得分:1)

我认为this thread from the SMO Forum包含答案。您只需要将其转换为SQL PowerShell语法(我相信这只是SMO的包装器)。

这是VBScript片段:

databaseHandle.FileGroups.Add(New FileGroup(db, "PRIMARY"))
databaseHandle.FileGroups(0).Files.Add(
    New DataFile(db.FileGroups(0), "TestName", "D:\SqlBancos\Teste\Teste1.mdf"))