-
Notifications
You must be signed in to change notification settings - Fork 16
/
Copy pathDataCompression.cs
56 lines (47 loc) · 1.57 KB
/
DataCompression.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
using System;
using System.Data;
using System.Data.SqlClient;
using System.Data.SqlTypes;
using Microsoft.SqlServer.Server;
using System.IO;
using System.IO.Compression;
public class DataCompression
{
[SqlFunction(IsDeterministic=true,DataAccess=DataAccessKind.None)]
public static SqlBytes fnCompress(SqlBytes blob)
{
if (blob.IsNull)
return blob;
byte[] blobData = blob.Buffer;
MemoryStream compressData = new MemoryStream();
DeflateStream compressor = new DeflateStream(compressData, CompressionMode.Compress, true);
compressor.Write(blobData, 0, blobData.Length);
compressor.Flush();
compressor.Close();
compressor = null;
return new SqlBytes(compressData);
}
[SqlFunction(IsDeterministic=true,DataAccess=DataAccessKind.None)]
public static SqlBytes fnDecompress(SqlBytes compressBlob)
{
if (compressBlob.IsNull)
return compressBlob;
DeflateStream decompressor = new DeflateStream(compressBlob.Stream, CompressionMode.Decompress, true);
int bytesRead = 1;
int chunkSize = 8192;
byte[] chunk = new byte[chunkSize];
MemoryStream decompressData = new MemoryStream();
try
{
while ((bytesRead = decompressor.Read(chunk, 0, chunkSize)) > 0)
{
decompressData.Write(chunk, 0, bytesRead);
}
}
finally
{
decompressor.Close();
}
return new SqlBytes(decompressData);
}
}