Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(SQL Server) Get the Index of a JSON MemberThis example demonstrates how to get the index of a given member by name. { "name": "donut", "image": { "fname": "donut.jpg", "w": 200, "h": 200 }, "thumbnail": { "fname": "donutThumb.jpg", "w": 32, "h": 32 } }
-- 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) DECLARE @json int -- Use "Chilkat_9_5_0.JsonObject" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.JsonObject', @json OUT IF @hr <> 0 BEGIN PRINT 'Failed to create ActiveX component' RETURN END -- This is the above JSON with whitespace chars removed (SPACE, TAB, CR, and LF chars). -- The presence of whitespace chars for pretty-printing makes no difference to the Load -- method. DECLARE @jsonStr nvarchar(4000) SELECT @jsonStr = '{"name": "donut","image":{"fname": "donut.jpg","w": 200,"h": 200},"thumbnail":{"fname": "donutThumb.jpg","w": 32,"h": 32}}' DECLARE @success int EXEC sp_OAMethod @json, 'Load', @success OUT, @jsonStr IF @success <> 1 BEGIN EXEC sp_OAGetProperty @json, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 EXEC @hr = sp_OADestroy @json RETURN END -- The top-level JSON object has three members: name, image, and thumbnail. DECLARE @nameIndex int EXEC sp_OAMethod @json, 'IndexOf', @nameIndex OUT, 'name' -- The index of the "name" member is 0. PRINT 'nameIndex = ' + @nameIndex DECLARE @thumbIndex int EXEC sp_OAMethod @json, 'IndexOf', @thumbIndex OUT, 'thumbnail' -- The index of the "thumbnail" member is 2. PRINT 'thumbIndex = ' + @thumbIndex -- The "fname" member is NOT a direct member of the top-level JSON object. -- It is a member of a nested object. If we try to get the index of this -- member using the top-level JSON object, it is not found (and returns -1). DECLARE @fnameIndex int EXEC sp_OAMethod @json, 'IndexOf', @fnameIndex OUT, 'fname' -- The fnameIndex is -1 (not found). This is correct. PRINT 'fnameIndex = ' + @fnameIndex -- Get the "image" object. DECLARE @imageObj int EXEC sp_OAMethod @json, 'ObjectOf', @imageObj OUT, 'image' EXEC sp_OAGetProperty @json, 'LastMethodSuccess', @iTmp0 OUT IF @iTmp0 = 0 BEGIN PRINT 'image object not found.' EXEC @hr = sp_OADestroy @json RETURN END -- Now we can get the index of the "fname" object, because it is a direct -- member of the "image" object: EXEC sp_OAMethod @imageObj, 'IndexOf', @fnameIndex OUT, 'fname' PRINT 'fnameIndex = ' + @fnameIndex EXEC @hr = sp_OADestroy @imageObj EXEC @hr = sp_OADestroy @json END GO |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.