Invoke-QB Cmdlet
Searches and updates QuickBooks data.
Syntax
Invoke-QB [parameters]
Remarks
The Invoke-QB cmdlet allows you to use SQL statements to execute any SQL statement directly. Below is the syntax for a parameterized query:
$query = Invoke-QB -Connection $connection -Query 'SELECT * FROM Customers WHERE Name=@Name' -Params @{'@Name'='Cook, Brian'}This cmdlet is also useful for executing stored procedures. Use the EXEC keyword to call a stored procedure:
$query = Invoke-QB -Connection $connection -Query 'EXEC ClearTransaction TxnID = @TxnID' -Params @{"300-1603373489"}To pass multiple Params parameters, use a semicolon (;) as a delimiter. The code below outlines the structure of an EXEC command with two parameters (param1 and param2):
$query = Invoke-QB -Connection $connection -Query 'EXEC MyStoredProc Input1=@param1, Input2=@param2' -Params @{'@param1' = 'value1'; '@param2' = 'value2'}