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) Compress XML ContentDemonstrates how to compress the content of an XML node. Note: This does not compress the node's children, only the text content. The input XML, available at http://www.chilkatsoft.com/data/compress1.xml, is this: <root> <fox>This is content that will be compressed. 0The quick brown fox jumps over the lazy dog 1The quick brown fox jumps over the lazy dog 2The quick brown fox jumps over the lazy dog 3The quick brown fox jumps over the lazy dog 4The quick brown fox jumps over the lazy dog 5The quick brown fox jumps over the lazy dog 6The quick brown fox jumps over the lazy dog 7The quick brown fox jumps over the lazy dog 8The quick brown fox jumps over the lazy dog 9The quick brown fox jumps over the lazy dog <child1> <grandchild>This is not compressed.</grandchild> </child1> </fox> </root>
-- Important: See this note about string length limitations for strings returned by sp_OAMethod calls. -- CREATE PROCEDURE ChilkatSample AS BEGIN DECLARE @hr int -- Important: Do not use nvarchar(max). See the warning about using nvarchar(max). DECLARE @sTmp0 nvarchar(4000) DECLARE @xml int -- Use "Chilkat_9_5_0.Xml" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.Xml', @xml OUT IF @hr <> 0 BEGIN PRINT 'Failed to create ActiveX component' RETURN END DECLARE @success int -- The sample input XML is available at http://www.chilkatsoft.com/data/compress1.xml EXEC sp_OAMethod @xml, 'LoadXmlFile', @success OUT, 'compress1.xml' IF @success <> 1 BEGIN EXEC sp_OAGetProperty @xml, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 EXEC @hr = sp_OADestroy @xml RETURN END -- Navigate to the "fox" node, which is the 1st child: EXEC sp_OAMethod @xml, 'FirstChild2', @success OUT -- Zip compress the content: EXEC sp_OAMethod @xml, 'ZipContent', @success OUT -- Navigate back to the root: EXEC sp_OAMethod @xml, 'GetRoot2', NULL -- Examine the new XML document: EXEC sp_OAMethod @xml, 'GetXml', @sTmp0 OUT PRINT @sTmp0 -- This is the XML w/ the compressed content in Base64 encoded format: -- <root> -- <fox><![CDATA[lcvbEYIwFIThZ5ixh63A8QZqHzTA5UiiIQeTIGr1xhJ2Zp/++bYxNiKvV5/EJyTTJqzWOXSS4zQH -- iVGG7aYsil1jBM/F9g90QVePm75xX6Y5Ql8S8lfg2u8Hg45/vyf9gfRH0p9IX5G+Jv2Z9BfSXwn/ -- Aw== -- ]]> -- <child1> -- <grandchild>This is not compressed.</grandchild> -- </child1> -- </fox> -- </root> -- Now uncompress and show that the original content was restored: EXEC sp_OAMethod @xml, 'FirstChild2', @success OUT EXEC sp_OAMethod @xml, 'UnzipContent', @success OUT EXEC sp_OAMethod @xml, 'GetRoot2', NULL EXEC sp_OAMethod @xml, 'GetXml', @sTmp0 OUT PRINT @sTmp0 EXEC @hr = sp_OADestroy @xml END GO |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.