firedac数据集和字符串之间相互转换

firedac数据集和字符串之间相互转换

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
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
/// <author>cxg 2018-12-20</author>
 
unit DatasetString;
 
interface
 
uses
  System.NetEncoding, FireDAC.Stan.Intf, System.ZLib, System.Classes, FireDAC.Comp.Client,
  System.SysUtils;
 
function DataSetToString(const ADataSet: TFDAdaptedDataSet): string;
 
function MemTableFromString(const AValue: string): TFDMemTable;
 
implementation
 
function DataSetToString(const ADataSet: TFDAdaptedDataSet): string;
var
  LBinary64: string;
  LMemoryStream: TMemoryStream;
  LStringStream: TStringStream;
  LDstStream: TMemoryStream;
  Zipper: TZCompressionStream;
begin
  LDstStream := TMemoryStream.Create;
  try
    LMemoryStream := TMemoryStream.Create;
    try
      ADataSet.SaveToStream(LMemoryStream, TFDStorageFormat.sfBinary);
      LMemoryStream.Seek(0, TSeekOrigin.soBeginning);
      Zipper := TZCompressionStream.Create(clDefault, LDstStream);
      try
        Zipper.CopyFrom(LMemoryStream, LMemoryStream.Size);
      finally
        Zipper.Free;
      end;
    finally
      LMemoryStream.Free;
    end;
    LDstStream.Seek(0, TSeekOrigin.soBeginning);
 
    LStringStream := TStringStream.Create;
    try
      TNetEncoding.Base64.Encode(LDstStream, LStringStream);
      LBinary64 := LStringStream.DataString;
    finally
      LStringStream.Free;
    end;
  finally
    LDstStream.Free;
  end;
  Result := LBinary64;
end;
 
function MemTableFromString(const AValue: string): TFDMemTable;
var
  LMemTable: TFDMemTable;
  LStringStream: TStringStream;
  LMemoryStream: TMemoryStream;
  LOrgStream: TMemoryStream;
  Unzipper: TZDecompressionStream;
begin
  LMemTable := TFDMemTable.Create(nil);
  LMemoryStream := TMemoryStream.Create;
  try
    LStringStream := TStringStream.Create(AValue);
    try
      LOrgStream := TMemoryStream.Create;
      try
        TNetEncoding.Base64.Decode(LStringStream, LOrgStream);
        LOrgStream.Seek(0, TSeekOrigin.soBeginning);
        Unzipper := TZDecompressionStream.Create(LOrgStream);
        try
          LMemoryStream.CopyFrom(Unzipper, Unzipper.Size);
        finally
          Unzipper.Free;
        end;
        LMemoryStream.Seek(0, TSeekOrigin.soBeginning);
      finally
        LOrgStream.Free;
      end;
    finally
      LStringStream.Free;
    end;
    LMemTable.LoadFromStream(LMemoryStream, TFDStorageFormat.sfBinary);
  finally
    LMemoryStream.Free;
  end;
  Result := LMemTable;
end;
 
end.

  

posted @   delphi中间件  阅读(688)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
历史上的今天:
2017-12-20 SynDBOracle.pas
2017-12-20 轻量级的REST中间件
2016-12-20 idhttp的用法
2016-12-20 firedac odbc sql server driver连接占线导致另一个hstmt
2016-12-20 论DATASNAP远程方法支持自定义对象作参数
2016-12-20 咏南中间件
点击右上角即可分享
微信分享提示