I have a strange error occurring when using the invoke-sqlcmd to insert rows into a table. The entire script works perfectly if executed one time, but if I run it a second time,
I know this is a rather old thread, but I ran into a similar issue which led me to this page. Here are the links that explained and resolved the issue for me.
PowerShell Invoke-Sqlcmd switches into sqlps session
Stuck in Powershell sqlserver
The SQLPS provider does not recognize UNC paths by default. You can either prefix the UNC path with a specific file system provider:
Get-ChildItem Microsoft.PowerShell.Core\FileSystem::\\pcslog1011\dtcs\ContractEmailNotes\
-Filter '*.txt'
or switch your working directory back to the default after the SQLPS module is loaded by adding this to the top of your script:
Push-Location
Import-Module SQLPS -DisableNameChecking
Pop-Location
It seems the issue is due to a combination of PowerShell switching the working directory from the default to that of the SQLPS provider in addition to the fact that the SQLPS provider doesn't recognize UNC paths (without some encouragement).
So where the normal PowerShell prompt looks something like this:
PS C:\Users\foobar>
It will instead look like the prompt below when you are working in the directory structure of the SQLPS provider (more on what this means here):
PS SQLSERVER:\>
In any event, the first time the script calls Get-ChildItem it is likely done so from the context of the default PowerShell working directory (where UNC paths are understood). However, calling Invoke-Sqlcmd loads the SQLPS module which changes the working directory to that of the provider which does not recognize UNC paths. So the next time Get-ChildItem is called, it is done so from within the directory structure of the provider, raising an error. The issue doesn't actually have anything to do with filter support.
Two ways others have found around this are to either prefix the UNC path with a file system provider so that SQLPS can parse it (source):
Get-ChildItem Microsoft.PowerShell.Core\FileSystem::\\pcslog1011\dtcs\ContractEmailNotes\ -Filter '*.txt'
Or switch back to the default working directory after the the SQLPS module loads. This is perhaps best done by explicitly loading the SQLPS provider at the beginning of your script and adding the Push/Pop-Location cmdlets before and after (no other changes required to the original script).
Push-Location
Import-Module SQLPS -DisableNameChecking
Pop-Location
Two final things to note. First, I've run my code against about 100 servers on different OS versions, patch levels and PowerShell versions. I've only seen this issue on some servers running PowerShell 5.1. Other 5.1 servers were fine.
Second, this whole affair can apparently be avoided by simply by using the newer SQLServer provider that is supposed to replace SQLPS.