0

在 PowerShell 中,我想运行 Invoke-DbaQuery dbatools 命令并使用带有 -File 参数的 UNC 路径:

Invoke-DbaQuery -SQLInstance $SQL_host -Database $DatabaseName -File "\\file_svr\scriptdir\userlist.sql"

该命令运行没有错误,但不产生任何输出。有谁知道这是否可能?如果是这样,我错过了什么?

4

1 回答 1

0

事实证明,调用一直在工作,但输出不可见。这是因为脚本有这样的代码:

DECLARE UserCursor CURSOR FOR 
SELECT  
  'CREATE USER ' + SPACE(1) + QUOTENAME([name]) + ' FOR LOGIN ' + QUOTENAME([name]) + ' WITH DEFAULT_SCHEMA = ' + QUOTENAME([default_schema_name]) + ';'
  AS [-- SQL STATEMENTS --]
FROM    sys.database_principals AS rm
WHERE [type] IN ('U', 'S', 'G') -- windows users, sql users, windows groups
AND [name] <> 'dbo'
AND [name] <> 'guest'
AND default_schema_name is not null

OPEN UserCursor

FETCH NEXT FROM UserCursor INTO @addUserScript
WHILE @@FETCH_STATUS = 0
BEGIN
    PRINT @addUserScript
    FETCH NEXT FROM UserCursor INTO @addUserScript
END

CLOSE UserCursor 
DEALLOCATE UserCursor;

然后解决方案是这样调用脚本:

Invoke-DbaQuery                  `
   -SQLInstance $HCM_SQL_host    `
   -Database $Refresh_database   `
   -Verbose 4>&1                 `
   -File "\\file-srv0\scriptdir\Userlist.sql" | `
    out-string -Width 250 | Out-File -FilePath $Create_Users_File_Fullname

请注意“-Verbose 4?&1 `”这一行,它将详细输出(即 PRINT 输出)重定向回标准输出,最终重定向回文件。

于 2021-09-23T22:15:23.280 回答