Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(SQL Server) Quickbooks Update an InvoiceDemonstrates how to update an invoice using the Quickbooks REST API. For more information, see https://www.developer.intuit.com/app/developer/qbo/docs/api/accounting/most-commonly-used/invoice#full-update-an-invoice
-- Important: See this note about string length limitations for strings returned by sp_OAMethod calls. -- CREATE PROCEDURE ChilkatSample AS BEGIN DECLARE @hr int DECLARE @iTmp0 int -- Important: Do not use nvarchar(max). See the warning about using nvarchar(max). DECLARE @sTmp0 nvarchar(4000) -- This example requires the Chilkat API to have been previously unlocked. -- See Global Unlock Sample for sample code. -- First get our previously obtained OAuth2 access token. DECLARE @jsonToken int -- Use "Chilkat_9_5_0.JsonObject" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.JsonObject', @jsonToken OUT IF @hr <> 0 BEGIN PRINT 'Failed to create ActiveX component' RETURN END DECLARE @success int EXEC sp_OAMethod @jsonToken, 'LoadFile', @success OUT, 'qa_data/tokens/qb-access-token.json' DECLARE @rest int -- Use "Chilkat_9_5_0.Rest" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.Rest', @rest OUT -- Connect to the REST server. DECLARE @bTls int SELECT @bTls = 1 DECLARE @port int SELECT @port = 443 DECLARE @bAutoReconnect int SELECT @bAutoReconnect = 1 DECLARE @success int EXEC sp_OAMethod @rest, 'Connect', @success OUT, 'sandbox-quickbooks.api.intuit.com', @port, @bTls, @bAutoReconnect DECLARE @sbAuth int -- Use "Chilkat_9_5_0.StringBuilder" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.StringBuilder', @sbAuth OUT EXEC sp_OAMethod @sbAuth, 'Append', @success OUT, 'Bearer ' EXEC sp_OAMethod @jsonToken, 'StringOf', @sTmp0 OUT, 'access_token' EXEC sp_OAMethod @sbAuth, 'Append', @success OUT, @sTmp0 EXEC sp_OAMethod @sbAuth, 'GetAsString', @sTmp0 OUT EXEC sp_OASetProperty @rest, 'Authorization', @sTmp0 -- -------------------------------------------------------------------------- -- Note: The above code to setup the initial REST connection -- can be done once. After connecting, any number of REST calls can be made. -- If the connection is lost, the next REST method call will automatically -- reconnect if needed. -- -------------------------------------------------------------------------- -- Create the following JSON: -- { -- "DocNumber": "1070", -- "SyncToken": "0", -- "domain": "QBO", -- "Balance": 150.0, -- "BillAddr": { -- "City": "Bayshore", -- "Line1": "4581 Finch St.", -- "PostalCode": "94326", -- "Lat": "INVALID", -- "Long": "INVALID", -- "CountrySubDivisionCode": "CA", -- "Id": "2" -- }, -- "TxnDate": "2015-07-24", -- "TotalAmt": 150.0, -- "CustomerRef": { -- "name": "Amy's Bird Sanctuary", -- "value": "1" -- }, -- "CustomerMemo": { -- "value": "Added customer memo." -- }, -- "ShipAddr": { -- "City": "Bayshore", -- "Line1": "4581 Finch St.", -- "PostalCode": "94326", -- "Lat": "INVALID", -- "Long": "INVALID", -- "CountrySubDivisionCode": "CA", -- "Id": "109" -- }, -- "LinkedTxn": [ -- ], -- "DueDate": "2015-08-23", -- "PrintStatus": "NeedToPrint", -- "EmailStatus": "NotSet", -- "sparse": false, -- "Line": [ -- { -- "LineNum": 1, -- "Amount": 150.0, -- "SalesItemLineDetail": { -- "TaxCodeRef": { -- "value": "NON" -- }, -- "ItemRef": { -- "name": "Services", -- "value": "1" -- } -- }, -- "Id": "1", -- "DetailType": "SalesItemLineDetail" -- }, -- { -- "DetailType": "SubTotalLineDetail", -- "Amount": 150.0, -- "SubTotalLineDetail": {} -- } -- ], -- "ApplyTaxAfterDiscount": false, -- "CustomField": [ -- { -- "DefinitionId": "1", -- "Type": "StringType", -- "Name": "Crew #" -- } -- ], -- "Id": "239", -- "TxnTaxDetail": { -- "TotalTax": 0 -- }, -- "MetaData": { -- "CreateTime": "2015-07-24T10:35:08-07:00", -- "LastUpdatedTime": "2015-07-24T10:35:08-07:00" -- } -- } -- -- Use the this online tool to generate the code from sample JSON: -- Generate Code to Create JSON DECLARE @jsonReq int -- Use "Chilkat_9_5_0.JsonObject" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.JsonObject', @jsonReq OUT EXEC sp_OAMethod @jsonReq, 'UpdateString', @success OUT, 'DocNumber', '1070' EXEC sp_OAMethod @jsonReq, 'UpdateString', @success OUT, 'SyncToken', '0' EXEC sp_OAMethod @jsonReq, 'UpdateString', @success OUT, 'domain', 'QBO' EXEC sp_OAMethod @jsonReq, 'UpdateNumber', @success OUT, 'Balance', '150.0' EXEC sp_OAMethod @jsonReq, 'UpdateString', @success OUT, 'BillAddr.City', 'Bayshore' EXEC sp_OAMethod @jsonReq, 'UpdateString', @success OUT, 'BillAddr.Line1', '4581 Finch St.' EXEC sp_OAMethod @jsonReq, 'UpdateString', @success OUT, 'BillAddr.PostalCode', '94326' EXEC sp_OAMethod @jsonReq, 'UpdateString', @success OUT, 'BillAddr.Lat', 'INVALID' EXEC sp_OAMethod @jsonReq, 'UpdateString', @success OUT, 'BillAddr.Long', 'INVALID' EXEC sp_OAMethod @jsonReq, 'UpdateString', @success OUT, 'BillAddr.CountrySubDivisionCode', 'CA' EXEC sp_OAMethod @jsonReq, 'UpdateString', @success OUT, 'BillAddr.Id', '2' EXEC sp_OAMethod @jsonReq, 'UpdateString', @success OUT, 'TxnDate', '2015-07-24' EXEC sp_OAMethod @jsonReq, 'UpdateNumber', @success OUT, 'TotalAmt', '150.0' EXEC sp_OAMethod @jsonReq, 'UpdateString', @success OUT, 'CustomerRef.name', 'Amy''s Bird Sanctuary' EXEC sp_OAMethod @jsonReq, 'UpdateString', @success OUT, 'CustomerRef.value', '1' EXEC sp_OAMethod @jsonReq, 'UpdateString', @success OUT, 'CustomerMemo.value', 'Added customer memo.' EXEC sp_OAMethod @jsonReq, 'UpdateString', @success OUT, 'ShipAddr.City', 'Bayshore' EXEC sp_OAMethod @jsonReq, 'UpdateString', @success OUT, 'ShipAddr.Line1', '4581 Finch St.' EXEC sp_OAMethod @jsonReq, 'UpdateString', @success OUT, 'ShipAddr.PostalCode', '94326' EXEC sp_OAMethod @jsonReq, 'UpdateString', @success OUT, 'ShipAddr.Lat', 'INVALID' EXEC sp_OAMethod @jsonReq, 'UpdateString', @success OUT, 'ShipAddr.Long', 'INVALID' EXEC sp_OAMethod @jsonReq, 'UpdateString', @success OUT, 'ShipAddr.CountrySubDivisionCode', 'CA' EXEC sp_OAMethod @jsonReq, 'UpdateString', @success OUT, 'ShipAddr.Id', '109' EXEC sp_OAMethod @jsonReq, 'UpdateNewArray', @success OUT, 'LinkedTxn' EXEC sp_OAMethod @jsonReq, 'UpdateString', @success OUT, 'DueDate', '2015-08-23' EXEC sp_OAMethod @jsonReq, 'UpdateString', @success OUT, 'PrintStatus', 'NeedToPrint' EXEC sp_OAMethod @jsonReq, 'UpdateString', @success OUT, 'EmailStatus', 'NotSet' EXEC sp_OAMethod @jsonReq, 'UpdateBool', @success OUT, 'sparse', 0 EXEC sp_OAMethod @jsonReq, 'UpdateInt', @success OUT, 'Line[0].LineNum', 1 EXEC sp_OAMethod @jsonReq, 'UpdateNumber', @success OUT, 'Line[0].Amount', '150.0' EXEC sp_OAMethod @jsonReq, 'UpdateString', @success OUT, 'Line[0].SalesItemLineDetail.TaxCodeRef.value', 'NON' EXEC sp_OAMethod @jsonReq, 'UpdateString', @success OUT, 'Line[0].SalesItemLineDetail.ItemRef.name', 'Services' EXEC sp_OAMethod @jsonReq, 'UpdateString', @success OUT, 'Line[0].SalesItemLineDetail.ItemRef.value', '1' EXEC sp_OAMethod @jsonReq, 'UpdateString', @success OUT, 'Line[0].Id', '1' EXEC sp_OAMethod @jsonReq, 'UpdateString', @success OUT, 'Line[0].DetailType', 'SalesItemLineDetail' EXEC sp_OAMethod @jsonReq, 'UpdateString', @success OUT, 'Line[1].DetailType', 'SubTotalLineDetail' EXEC sp_OAMethod @jsonReq, 'UpdateNumber', @success OUT, 'Line[1].Amount', '150.0' EXEC sp_OAMethod @jsonReq, 'UpdateNewObject', @success OUT, 'Line[1].SubTotalLineDetail' EXEC sp_OAMethod @jsonReq, 'UpdateBool', @success OUT, 'ApplyTaxAfterDiscount', 0 EXEC sp_OAMethod @jsonReq, 'UpdateString', @success OUT, 'CustomField[0].DefinitionId', '1' EXEC sp_OAMethod @jsonReq, 'UpdateString', @success OUT, 'CustomField[0].Type', 'StringType' EXEC sp_OAMethod @jsonReq, 'UpdateString', @success OUT, 'CustomField[0].Name', 'Crew #' EXEC sp_OAMethod @jsonReq, 'UpdateString', @success OUT, 'Id', '239' EXEC sp_OAMethod @jsonReq, 'UpdateInt', @success OUT, 'TxnTaxDetail.TotalTax', 0 EXEC sp_OAMethod @jsonReq, 'UpdateString', @success OUT, 'MetaData.CreateTime', '2015-07-24T10:35:08-07:00' EXEC sp_OAMethod @jsonReq, 'UpdateString', @success OUT, 'MetaData.LastUpdatedTime', '2015-07-24T10:35:08-07:00' DECLARE @sbRequestBody int -- Use "Chilkat_9_5_0.StringBuilder" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.StringBuilder', @sbRequestBody OUT EXEC sp_OAMethod @jsonReq, 'EmitSb', @success OUT, @sbRequestBody EXEC sp_OAMethod @rest, 'AddHeader', @success OUT, 'Content-Type', 'application/json' EXEC sp_OAMethod @rest, 'AddHeader', @success OUT, 'Accept', 'application/json' EXEC sp_OASetProperty @rest, 'AllowHeaderFolding', 0 DECLARE @sbResponseBody int -- Use "Chilkat_9_5_0.StringBuilder" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.StringBuilder', @sbResponseBody OUT EXEC sp_OAMethod @rest, 'FullRequestSb', @success OUT, 'POST', '/v3/company/<realmID>/invoice', @sbRequestBody, @sbResponseBody IF @success <> 1 BEGIN EXEC sp_OAGetProperty @rest, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 EXEC @hr = sp_OADestroy @jsonToken EXEC @hr = sp_OADestroy @rest EXEC @hr = sp_OADestroy @sbAuth EXEC @hr = sp_OADestroy @jsonReq EXEC @hr = sp_OADestroy @sbRequestBody EXEC @hr = sp_OADestroy @sbResponseBody RETURN END DECLARE @respStatusCode int EXEC sp_OAGetProperty @rest, 'ResponseStatusCode', @respStatusCode OUT -- Success is indicated by a 200 response status code. PRINT 'response status code = ' + @respStatusCode DECLARE @jsonResponse int -- Use "Chilkat_9_5_0.JsonObject" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.JsonObject', @jsonResponse OUT EXEC sp_OAMethod @jsonResponse, 'LoadSb', @success OUT, @sbResponseBody EXEC sp_OASetProperty @jsonResponse, 'EmitCompact', 0 EXEC sp_OAMethod @jsonResponse, 'Emit', @sTmp0 OUT PRINT @sTmp0 EXEC sp_OAGetProperty @rest, 'ResponseStatusCode', @iTmp0 OUT IF @iTmp0 <> 200 BEGIN PRINT 'Failed.' EXEC @hr = sp_OADestroy @jsonToken EXEC @hr = sp_OADestroy @rest EXEC @hr = sp_OADestroy @sbAuth EXEC @hr = sp_OADestroy @jsonReq EXEC @hr = sp_OADestroy @sbRequestBody EXEC @hr = sp_OADestroy @sbResponseBody EXEC @hr = sp_OADestroy @jsonResponse RETURN END -- Sample output... -- (See the parsing code below..) -- -- Use the this online tool to generate parsing code from sample JSON: -- Generate Parsing Code from JSON -- { -- "Invoice": { -- "TxnDate": "2015-07-24", -- "domain": "QBO", -- "PrintStatus": "NeedToPrint", -- "TotalAmt": 150.0, -- "Line": [ -- { -- "LineNum": 1, -- "Amount": 150.0, -- "SalesItemLineDetail": { -- "TaxCodeRef": { -- "value": "NON" -- }, -- "ItemRef": { -- "name": "Services", -- "value": "1" -- } -- }, -- "Id": "1", -- "DetailType": "SalesItemLineDetail" -- }, -- { -- "DetailType": "SubTotalLineDetail", -- "Amount": 150.0, -- "SubTotalLineDetail": {} -- } -- ], -- "DueDate": "2015-08-23", -- "ApplyTaxAfterDiscount": false, -- "DocNumber": "1070", -- "sparse": false, -- "CustomerMemo": { -- "value": "Added customer memo." -- }, -- "Deposit": 0, -- "Balance": 150.0, -- "CustomerRef": { -- "name": "Amy's Bird Sanctuary", -- "value": "1" -- }, -- "TxnTaxDetail": { -- "TotalTax": 0 -- }, -- "SyncToken": "1", -- "LinkedTxn": [ -- ], -- "ShipAddr": { -- "CountrySubDivisionCode": "CA", -- "City": "Bayshore", -- "PostalCode": "94326", -- "Id": "118", -- "Line1": "4581 Finch St." -- }, -- "EmailStatus": "NotSet", -- "BillAddr": { -- "CountrySubDivisionCode": "CA", -- "City": "Bayshore", -- "PostalCode": "94326", -- "Id": "117", -- "Line1": "4581 Finch St." -- }, -- "MetaData": { -- "CreateTime": "2015-07-24T10:35:08-07:00", -- "LastUpdatedTime": "2015-07-24T10:53:39-07:00" -- }, -- "CustomField": [ -- { -- "DefinitionId": "1", -- "Type": "StringType", -- "Name": "Crew #" -- } -- ], -- "Id": "239" -- }, -- "time": "2015-07-24T10:53:39.287-07:00" -- } -- DECLARE @LineNum int DECLARE @Amount nvarchar(4000) DECLARE @SalesItemLineDetailTaxCodeRefValue nvarchar(4000) DECLARE @SalesItemLineDetailItemRefName nvarchar(4000) DECLARE @SalesItemLineDetailItemRefValue nvarchar(4000) DECLARE @Id nvarchar(4000) DECLARE @DetailType nvarchar(4000) DECLARE @DefinitionId nvarchar(4000) DECLARE @invType nvarchar(4000) DECLARE @Name nvarchar(4000) DECLARE @InvoiceTxnDate nvarchar(4000) EXEC sp_OAMethod @jsonResponse, 'StringOf', @InvoiceTxnDate OUT, 'Invoice.TxnDate' DECLARE @InvoiceDomain nvarchar(4000) EXEC sp_OAMethod @jsonResponse, 'StringOf', @InvoiceDomain OUT, 'Invoice.domain' DECLARE @InvoicePrintStatus nvarchar(4000) EXEC sp_OAMethod @jsonResponse, 'StringOf', @InvoicePrintStatus OUT, 'Invoice.PrintStatus' DECLARE @InvoiceTotalAmt nvarchar(4000) EXEC sp_OAMethod @jsonResponse, 'StringOf', @InvoiceTotalAmt OUT, 'Invoice.TotalAmt' DECLARE @InvoiceDueDate nvarchar(4000) EXEC sp_OAMethod @jsonResponse, 'StringOf', @InvoiceDueDate OUT, 'Invoice.DueDate' DECLARE @InvoiceApplyTaxAfterDiscount int EXEC sp_OAMethod @jsonResponse, 'BoolOf', @InvoiceApplyTaxAfterDiscount OUT, 'Invoice.ApplyTaxAfterDiscount' DECLARE @InvoiceDocNumber nvarchar(4000) EXEC sp_OAMethod @jsonResponse, 'StringOf', @InvoiceDocNumber OUT, 'Invoice.DocNumber' DECLARE @InvoiceSparse int EXEC sp_OAMethod @jsonResponse, 'BoolOf', @InvoiceSparse OUT, 'Invoice.sparse' DECLARE @InvoiceCustomerMemoValue nvarchar(4000) EXEC sp_OAMethod @jsonResponse, 'StringOf', @InvoiceCustomerMemoValue OUT, 'Invoice.CustomerMemo.value' DECLARE @InvoiceDeposit int EXEC sp_OAMethod @jsonResponse, 'IntOf', @InvoiceDeposit OUT, 'Invoice.Deposit' DECLARE @InvoiceBalance nvarchar(4000) EXEC sp_OAMethod @jsonResponse, 'StringOf', @InvoiceBalance OUT, 'Invoice.Balance' DECLARE @InvoiceCustomerRefName nvarchar(4000) EXEC sp_OAMethod @jsonResponse, 'StringOf', @InvoiceCustomerRefName OUT, 'Invoice.CustomerRef.name' DECLARE @InvoiceCustomerRefValue nvarchar(4000) EXEC sp_OAMethod @jsonResponse, 'StringOf', @InvoiceCustomerRefValue OUT, 'Invoice.CustomerRef.value' DECLARE @InvoiceTxnTaxDetailTotalTax int EXEC sp_OAMethod @jsonResponse, 'IntOf', @InvoiceTxnTaxDetailTotalTax OUT, 'Invoice.TxnTaxDetail.TotalTax' DECLARE @InvoiceSyncToken nvarchar(4000) EXEC sp_OAMethod @jsonResponse, 'StringOf', @InvoiceSyncToken OUT, 'Invoice.SyncToken' DECLARE @InvoiceShipAddrCountrySubDivisionCode nvarchar(4000) EXEC sp_OAMethod @jsonResponse, 'StringOf', @InvoiceShipAddrCountrySubDivisionCode OUT, 'Invoice.ShipAddr.CountrySubDivisionCode' DECLARE @InvoiceShipAddrCity nvarchar(4000) EXEC sp_OAMethod @jsonResponse, 'StringOf', @InvoiceShipAddrCity OUT, 'Invoice.ShipAddr.City' DECLARE @InvoiceShipAddrPostalCode nvarchar(4000) EXEC sp_OAMethod @jsonResponse, 'StringOf', @InvoiceShipAddrPostalCode OUT, 'Invoice.ShipAddr.PostalCode' DECLARE @InvoiceShipAddrId nvarchar(4000) EXEC sp_OAMethod @jsonResponse, 'StringOf', @InvoiceShipAddrId OUT, 'Invoice.ShipAddr.Id' DECLARE @InvoiceShipAddrLine1 nvarchar(4000) EXEC sp_OAMethod @jsonResponse, 'StringOf', @InvoiceShipAddrLine1 OUT, 'Invoice.ShipAddr.Line1' DECLARE @InvoiceEmailStatus nvarchar(4000) EXEC sp_OAMethod @jsonResponse, 'StringOf', @InvoiceEmailStatus OUT, 'Invoice.EmailStatus' DECLARE @InvoiceBillAddrCountrySubDivisionCode nvarchar(4000) EXEC sp_OAMethod @jsonResponse, 'StringOf', @InvoiceBillAddrCountrySubDivisionCode OUT, 'Invoice.BillAddr.CountrySubDivisionCode' DECLARE @InvoiceBillAddrCity nvarchar(4000) EXEC sp_OAMethod @jsonResponse, 'StringOf', @InvoiceBillAddrCity OUT, 'Invoice.BillAddr.City' DECLARE @InvoiceBillAddrPostalCode nvarchar(4000) EXEC sp_OAMethod @jsonResponse, 'StringOf', @InvoiceBillAddrPostalCode OUT, 'Invoice.BillAddr.PostalCode' DECLARE @InvoiceBillAddrId nvarchar(4000) EXEC sp_OAMethod @jsonResponse, 'StringOf', @InvoiceBillAddrId OUT, 'Invoice.BillAddr.Id' DECLARE @InvoiceBillAddrLine1 nvarchar(4000) EXEC sp_OAMethod @jsonResponse, 'StringOf', @InvoiceBillAddrLine1 OUT, 'Invoice.BillAddr.Line1' DECLARE @InvoiceMetaDataCreateTime nvarchar(4000) EXEC sp_OAMethod @jsonResponse, 'StringOf', @InvoiceMetaDataCreateTime OUT, 'Invoice.MetaData.CreateTime' DECLARE @InvoiceMetaDataLastUpdatedTime nvarchar(4000) EXEC sp_OAMethod @jsonResponse, 'StringOf', @InvoiceMetaDataLastUpdatedTime OUT, 'Invoice.MetaData.LastUpdatedTime' DECLARE @InvoiceId nvarchar(4000) EXEC sp_OAMethod @jsonResponse, 'StringOf', @InvoiceId OUT, 'Invoice.Id' DECLARE @time nvarchar(4000) EXEC sp_OAMethod @jsonResponse, 'StringOf', @time OUT, 'time' DECLARE @i int SELECT @i = 0 DECLARE @count_i int EXEC sp_OAMethod @jsonResponse, 'SizeOfArray', @count_i OUT, 'Invoice.Line' WHILE @i < @count_i BEGIN EXEC sp_OASetProperty @jsonResponse, 'I', @i EXEC sp_OAMethod @jsonResponse, 'IntOf', @LineNum OUT, 'Invoice.Line[i].LineNum' EXEC sp_OAMethod @jsonResponse, 'StringOf', @Amount OUT, 'Invoice.Line[i].Amount' EXEC sp_OAMethod @jsonResponse, 'StringOf', @SalesItemLineDetailTaxCodeRefValue OUT, 'Invoice.Line[i].SalesItemLineDetail.TaxCodeRef.value' EXEC sp_OAMethod @jsonResponse, 'StringOf', @SalesItemLineDetailItemRefName OUT, 'Invoice.Line[i].SalesItemLineDetail.ItemRef.name' EXEC sp_OAMethod @jsonResponse, 'StringOf', @SalesItemLineDetailItemRefValue OUT, 'Invoice.Line[i].SalesItemLineDetail.ItemRef.value' EXEC sp_OAMethod @jsonResponse, 'StringOf', @Id OUT, 'Invoice.Line[i].Id' EXEC sp_OAMethod @jsonResponse, 'StringOf', @DetailType OUT, 'Invoice.Line[i].DetailType' SELECT @i = @i + 1 END SELECT @i = 0 EXEC sp_OAMethod @jsonResponse, 'SizeOfArray', @count_i OUT, 'Invoice.LinkedTxn' WHILE @i < @count_i BEGIN EXEC sp_OASetProperty @jsonResponse, 'I', @i SELECT @i = @i + 1 END SELECT @i = 0 EXEC sp_OAMethod @jsonResponse, 'SizeOfArray', @count_i OUT, 'Invoice.CustomField' WHILE @i < @count_i BEGIN EXEC sp_OASetProperty @jsonResponse, 'I', @i EXEC sp_OAMethod @jsonResponse, 'StringOf', @DefinitionId OUT, 'Invoice.CustomField[i].DefinitionId' EXEC sp_OAMethod @jsonResponse, 'StringOf', @invType OUT, 'Invoice.CustomField[i].Type' EXEC sp_OAMethod @jsonResponse, 'StringOf', @Name OUT, 'Invoice.CustomField[i].Name' SELECT @i = @i + 1 END EXEC @hr = sp_OADestroy @jsonToken EXEC @hr = sp_OADestroy @rest EXEC @hr = sp_OADestroy @sbAuth EXEC @hr = sp_OADestroy @jsonReq EXEC @hr = sp_OADestroy @sbRequestBody EXEC @hr = sp_OADestroy @sbResponseBody EXEC @hr = sp_OADestroy @jsonResponse END GO |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.