我正在将集成测试添加到CI构建过程中。
我有一个(通过dacpac)部署到TFS服务器上的localDb实例的数据库项目。(工作中)
下一步是将测试数据加载到数据库中。我正在尝试导入SQLPS模块,然后运行Invoke-SqlCmd命令小程序。
Import-Module 'SQLPS' -DisableNameChecking;
Invoke-Sqlcmd -InputFile "$localDirectory\products\$branch\UnitTestData.sql" -ServerInstance "(localdb)\v12.0" -Database "[db]"我一直收到无法识别SQLPS的错误消息。
TFS服务器安装了SQL server 2012 -但我使用的是2014年的对象。我已经安装了SQL 2014功能包,以便powertools在服务器和构建代理上可用。
这看起来很例行公事--但我不确定我错在哪里。
发布于 2017-07-12 03:51:39
把这事搞清楚了。Powershell不是我的强项之一,所以对于在构建服务器上寻找SQL server Powershell工具的任何其他人来说。
您需要在构建服务器上安装SQL server Feature Pack (如果没有安装SQL Server )。该功能包可用于2012及更高版本。
您需要的具体项目包括: SQL CLR类型SQL共享管理对象Powershell工具
Powershell工具将安装在C:\Program Files\Microsoft SQL Server{版本}\ tools \PowerShell\Modules目录中。其中{版本: 110=2012,120=2014,130=2016}
使用PS工具的路径引用-您所需做的就是创建一个本地模块路径引用:
Param(
[Parameter(Mandatory=$True)][string]$server,
[Parameter(Mandatory=$True)][string]$database,
[Parameter(Mandatory=$True)][string]$sqlPowerToolsPath,
[Parameter(Mandatory=$True)][string]$sqlFile
)
$env:PSModulePath = $env:PSModulePath + ";$sqlPowerToolsPath"我的PS脚本接受服务器、数据库、sqlPowerToolsPath、sqlFile等参数,并将本地会话PSModulePath设置为在参数中包含路径。在我的例子中,C:\Program Files\Microsoft SQL Server\120\Tools\PowerShell\Modules。
脚本的其余部分导入SQLPS模块并执行参数中指定的SQL文件:
Import-Module 'SQLPS' -DisableNameChecking;
$sql = [Io.File]::ReadAllText($sqlFile);
Invoke-Sqlcmd -Query $sql -ServerInstance "$server" -Database "$database"https://stackoverflow.com/questions/45023415
复制相似问题