我想知道在后续查询中是否有任何方法可以使用数据集的值 这是一个例子:
作品:
$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时转换失败。”
知道如何使用正确类型的这些值,而不创建单独的变量吗?
答案 0 :(得分:9)
你需要在双引号字符串中使用$($ Item.ID),它会起作用。