sql >> Databáze >  >> RDS >> Sqlserver

.NET komprese XML pro uložení v databázi SQL Server

Tento článek vám může pomoci začít.

Následující fragment může zkomprimovat řetězec a vrátit výsledek s kódováním base-64:

public static string Compress(string text)
{
 byte[] buffer = Encoding.UTF8.GetBytes(text);
 MemoryStream ms = new MemoryStream();
 using (GZipStream zip = new GZipStream(ms, CompressionMode.Compress, true))
 {
  zip.Write(buffer, 0, buffer.Length);
 }

 ms.Position = 0;
 MemoryStream outStream = new MemoryStream();

 byte[] compressed = new byte[ms.Length];
 ms.Read(compressed, 0, compressed.Length);

 byte[] gzBuffer = new byte[compressed.Length + 4];
 System.Buffer.BlockCopy(compressed, 0, gzBuffer, 4, compressed.Length);
 System.Buffer.BlockCopy(BitConverter.GetBytes(buffer.Length), 0, gzBuffer, 0, 4);
 return Convert.ToBase64String (gzBuffer);
}

EDIT:Kromě toho možná budete chtít používat formáty CLOB i při ukládání XML jako textu, protože varchars mají velmi omezenou délku – kterou XML může často rychle překročit.



  1. MySQL:Omezení a problémy GET_LOCK

  2. Vrátit náhodné výsledky ( pořadí podle rand() )

  3. Jedinečné pouzdro na klíče není citlivé

  4. SQL Server - Jak zapisovat proměnné a výsledky dotazů do textového souboru?