0

我已经开始尝试使用 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)
4

1 回答 1

1

我认为来自 SMO 论坛的这个帖子包含了答案。您只需要将其转换为 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"))
于 2013-02-21T18:36:13.920 回答