提问人:John Saunders 提问时间:5/8/2013 更新时间:5/21/2014 访问量:1211
“无法确定目标数据库架构提供程序” 使用 VSDBCMD,但仅在指定 /ConnectionString 时
"The target database schema provider could not be determined" With VSDBCMD but Only When /ConnectionString is Specified
问:
我一直在开发一个部署脚本,将我们的数据库项目部署到多个数据库实例。我正在通过手动运行它来测试它。这是一个非常简单的脚本,只是针对为部署基本数据库或模板数据库而创建的部署清单运行 VSDBCMD。为了部署到同一服务器上的不同数据库,该脚本使用部署清单,但随后还指定 /p:DatabaseName 和 /p:TargetDatabase 属性。
这已经工作了一整天。
我们对这些数据库使用 SQL Server 身份验证,我希望能够将用户名和密码指定为脚本的参数,这样就不必对它们进行硬编码。我能看到的唯一方法是使用 /ConnectionString 开关。这就是导致失败的原因。即使我指定了与部署清单中存储的完全相同的连接字符串,脚本也会失败,并显示错误“无法确定目标数据库架构提供程序”。脚本:
function DeployDatabase([string] $manifestPath, [string] $password, [string] $instance, [string] $server, [string] $user)
{
$vsdbcmdPath = "c:\Program Files (x86)\Microsoft Visual Studio 10.0\VSTSDB\Deploy"
$vsdbcmd = "$vsdbcmdPath\vsdbcmd.exe"
$outputScriptPath = "$instance.sql"
$logPath = "$instance.log"
$connectionString = "Data Source=$server;User ID=$user;"
& $vsdbcmd /dd /dsp:SQL /manifest:$manifestPath /a:Deploy /p:DatabaseName=$instance /p:TargetDatabase=$instance /script:$outputScriptPath /cs:"$connectionString" |
Out-File -FilePath $logPath
}
# Actual call is omitted to protect the $server, $user and $password
只需省略 /cs 开关即可再次成功。请注意,从上面的连接字符串中可以看出,甚至不需要在连接字符串中指定密码即可导致失败。
目标数据库服务器运行的是 SQL Server 2008 R2,并且是最新的修补程序。
我想知道如何避免此错误,或者我想知道在部署时指定用户名和密码的更好方法,而无需密码以明文形式出现在部署清单中。
答:
1赞
Junior Mayhé
5/21/2014
#1
我有同样的问题。您是否尝试设置实例名称?
连接字符串中的 SQL 实例名称可能错误。
如果您未使用集成安全性,请仔细检查是否设置了用户 ID 和密码。
评论