首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >导入-在TFS 2015上无法识别模块SQLPS

导入-在TFS 2015上无法识别模块SQLPS
EN

Stack Overflow用户
提问于 2017-07-11 08:08:00
回答 1查看 341关注 0票数 0

我正在将集成测试添加到CI构建过程中。

我有一个(通过dacpac)部署到TFS服务器上的localDb实例的数据库项目。(工作中)

下一步是将测试数据加载到数据库中。我正在尝试导入SQLPS模块,然后运行Invoke-SqlCmd命令小程序。

代码语言:javascript
复制
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在服务器和构建代理上可用。

这看起来很例行公事--但我不确定我错在哪里。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 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工具的路径引用-您所需做的就是创建一个本地模块路径引用:

代码语言:javascript
复制
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文件:

代码语言:javascript
复制
Import-Module 'SQLPS' -DisableNameChecking;
$sql = [Io.File]::ReadAllText($sqlFile);
Invoke-Sqlcmd -Query $sql -ServerInstance "$server" -Database "$database"
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/45023415

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档