Powershell SqlCmd – 使用结果值而不定义变量

我想知道是否有任何方法可以在后续查询中使用数据集的值.
这是一个例子:

作品:

$Result = Invoke-sqlcmd -query "SELECT Id,FirstName,LastName FROM Person" 
foreach($item in $Result){
  $ID= $item.Id 
  $SaleResults = Invoke-sqlcmd -query "SELECT * FROM Sales WHERE Salesperson = $ID"
}

不起作用:

foreach($item in $Result){
  $SaleResults = Invoke-sqlcmd -query "SELECT * FROM Sales WHERE Salesperson=$Item.Id"
}

第二个示例失败,因为它使用$Item.Id作为字符串而不是uniqueidentifier,因此错误:“从字符串转换为uniqueidentifier时转换失败”.

知道如何使用正确类型的这些值,而不创建单独的变量?

解决方法

你需要在双引号字符串中使用$($Item.ID),它会起作用.

相关文章

SELECT a.*,b.dp_name,c.pa_name,fm_name=(CASE WHEN a.fm_n...
if not exists(select name from syscolumns where name=&am...
select a.*,pano=a.pa_no,b.pa_name,f.dp_name,e.fw_state_n...
要在 SQL Server 2019 中设置定时自动重启,可以使用 Window...
您收到的错误消息表明数据库 'EastRiver' 的...
首先我需要查询出需要使用SQL Server Profiler跟踪的数据库标...