mormot json序列(还原)

mormot json序列(还原)

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
93
94
95
96
97
98
99
100
101
/// <author>cxg 2021-5-28</author>
/// delphi7 + mormot1.18
/// json序列\还原
(* people.json
[
{"RowID":3,"FirstName":"咏南","LastName":"Rachmaninoff","Data":"?w6l6w6di","YearOfBirth":1800,"YearOfDeath":1943},
{"RowID":4,"FirstName":"中间件","LastName":"Dumas","Data":"?w6nDp2I=","YearOfBirth":1801,"YearOfDeath":1870},
{"RowID":7,"FirstName":"rest","LastName":"Huxley","Data":"?w6nDoA==","YearOfBirth":1802,"YearOfDeath":1963},
]
*)
 
unit Unit1;
 
interface
 
uses
  mORMot, SynCommons, Contnrs,
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, StdCtrls;
 
type
  TForm1 = class(TForm)
    Button1: TButton;
    Memo1: TMemo;
    Button2: TButton;
    procedure Button1Click(Sender: TObject);
    procedure FormCreate(Sender: TObject);
    procedure Button2Click(Sender: TObject);
  private
    { Private declarations }
    fFileName: string;
  public
    { Public declarations }
  end;
 
var
  Form1: TForm1;
 
implementation
 
{$R *.dfm}
 
type
  TSQLRecordPeople = class(TSQLRecord)
  private
    fData: TSQLRawBlob;
    fFirstName: RawUTF8;
    fLastName: RawUTF8;
    fYearOfBirth: integer;
    fYearOfDeath: word;
  published
    property FirstName: RawUTF8 read fFirstName write fFirstName;
    property LastName: RawUTF8 read fLastName write fLastName;
    property Data: TSQLRawBlob read fData write fData;
    property YearOfBirth: integer read fYearOfBirth write fYearOfBirth;
    property YearOfDeath: word read fYearOfDeath write fYearOfDeath;
  end;
 
procedure TForm1.Button1Click(Sender: TObject);
//从json还原对象1
var json: RawUTF8;
    i: integer;
    list: TSQLTableJSON;
    doc: TObjectList;
    p: TSQLRecordPeople;
begin
  json := StringFromFile(fFileName);
  list := TSQLTableJSON.Create('',pointer(json),length(json));
  doc := list.ToObjectList(TSQLRecordPeople);
  list.Free;
  json := '';
  for i := 0 to doc.Count-1 do
  begin
    p := TSQLRecordPeople(doc.List[i]);
    Memo1.Lines.Add(Utf8ToAnsi(p.fFirstName));
  end;
  doc.Free;
end;
 
procedure TForm1.FormCreate(Sender: TObject);
begin
  fFileName := 'people.json';
  Memo1.Clear;
end;
 
procedure TForm1.Button2Click(Sender: TObject);
//从json还原对象2
var p: TSQLRecordPeople;
    json: RawUTF8;
begin
  json := StringFromFile(fFileName);
  p := TSQLRecordPeople.CreateAndFillPrepare(json);
  json := '';
  while p.FillOne do
  begin
    Memo1.Lines.Add(Utf8ToAnsi(p.FirstName));
  end;
  p.Free;
end;
 
end.

  

posted @   delphi中间件  阅读(254)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
点击右上角即可分享
微信分享提示