咏南中间件JSON序列类

咏南中间件JSON序列类

1)支持跨平台、跨语言

2)支持主从表数据序列、还原,支持任意数量的表

主从表数据序列为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
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
{
    "rows": [
        {
            "FDBS": {
                "Version": 15,
                "Manager": {
                    "UpdatesRegistry": true,
                    "TableList": [
                        {
                            "class": "Table",
                            "Name": "qryOpen",
                            "SourceName": "tgoods",
                            "SourceID": 1,
                            "TabID": 0,
                            "EnforceConstraints": false,
                            "MinimumCapacity": 50,
                            "CheckReadOnly": false,
                            "ColumnList": [
                                {
                                    "class": "Column",
                                    "Name": "goodsid",
                                    "SourceName": "goodsid",
                                    "SourceID": 1,
                                    "DataType": "AnsiString",
                                    "Size": 8,
                                    "Searchable": true,
                                    "Base": true,
                                    "OInUpdate": true,
                                    "OInWhere": true,
                                    "OInKey": true,
                                    "OriginColName": "goodsid",
                                    "SourcePrecision": 8,
                                    "SourceSize": 8
                                },
                                {
                                    "class": "Column",
                                    "Name": "barcode",
                                    "SourceName": "barcode",
                                    "SourceID": 2,
                                    "DataType": "AnsiString",
                                    "Size": 18,
                                    "Searchable": true,
                                    "AllowNull": true,
                                    "Base": true,
                                    "OAllowNull": true,
                                    "OInUpdate": true,
                                    "OInWhere": true,
                                    "OriginColName": "barcode",
                                    "SourcePrecision": 18,
                                    "SourceSize": 18
                                },
                                {
                                    "class": "Column",
                                    "Name": "goodsname",
                                    "SourceName": "goodsname",
                                    "SourceID": 3,
                                    "DataType": "AnsiString",
                                    "Size": 50,
                                    "Searchable": true,
                                    "Base": true,
                                    "OInUpdate": true,
                                    "OInWhere": true,
                                    "OriginColName": "goodsname",
                                    "SourcePrecision": 50,
                                    "SourceSize": 50
                                },
                                {
                                    "class": "Column",
                                    "Name": "pyjm",
                                    "SourceName": "pyjm",
                                    "SourceID": 4,
                                    "DataType": "AnsiString",
                                    "Size": 50,
                                    "Searchable": true,
                                    "AllowNull": true,
                                    "Base": true,
                                    "OAllowNull": true,
                                    "OInUpdate": true,
                                    "OInWhere": true,
                                    "OriginColName": "pyjm",
                                    "SourcePrecision": 50,
                                    "SourceSize": 50
                                },
                                {
                                    "class": "Column",
                                    "Name": "gg",
                                    "SourceName": "gg",
                                    "SourceID": 5,
                                    "DataType": "AnsiString",
                                    "Size": 30,
                                    "Searchable": true,
                                    "AllowNull": true,
                                    "Base": true,
                                    "OAllowNull": true,
                                    "OInUpdate": true,
                                    "OInWhere": true,
                                    "OriginColName": "gg",
                                    "SourcePrecision": 30,
                                    "SourceSize": 30
                                },
                                {
                                    "class": "Column",
                                    "Name": "kindid",
                                    "SourceName": "kindid",
                                    "SourceID": 6,
                                    "DataType": "AnsiString",
                                    "Size": 8,
                                    "Searchable": true,
                                    "AllowNull": true,
                                    "Base": true,
                                    "OAllowNull": true,
                                    "OInUpdate": true,
                                    "OInWhere": true,
                                    "OriginColName": "kindid",
                                    "SourcePrecision": 8,
                                    "SourceSize": 8
                                },
                                {
                                    "class": "Column",
                                    "Name": "jj",
                                    "SourceName": "jj",
                                    "SourceID": 7,
                                    "DataType": "BCD",
                                    "Precision": 18,
                                    "Scale": 4,
                                    "Searchable": true,
                                    "AllowNull": true,
                                    "Base": true,
                                    "OAllowNull": true,
                                    "OInUpdate": true,
                                    "OInWhere": true,
                                    "OriginColName": "jj",
                                    "SourcePrecision": 18,
                                    "SourceScale": 4
                                },
                                {
                                    "class": "Column",
                                    "Name": "lsj",
                                    "SourceName": "lsj",
                                    "SourceID": 8,
                                    "DataType": "BCD",
                                    "Precision": 18,
                                    "Scale": 4,
                                    "Searchable": true,
                                    "AllowNull": true,
                                    "Base": true,
                                    "OAllowNull": true,
                                    "OInUpdate": true,
                                    "OInWhere": true,
                                    "OriginColName": "lsj",
                                    "SourcePrecision": 18,
                                    "SourceScale": 4
                                },
                                {
                                    "class": "Column",
                                    "Name": "kcxx",
                                    "SourceName": "kcxx",
                                    "SourceID": 9,
                                    "DataType": "BCD",
                                    "Precision": 18,
                                    "Scale": 4,
                                    "Searchable": true,
                                    "AllowNull": true,
                                    "Base": true,
                                    "OAllowNull": true,
                                    "OInUpdate": true,
                                    "OInWhere": true,
                                    "OriginColName": "kcxx",
                                    "SourcePrecision": 18,
                                    "SourceScale": 4
                                },
                                {
                                    "class": "Column",
                                    "Name": "kcsx",
                                    "SourceName": "kcsx",
                                    "SourceID": 10,
                                    "DataType": "BCD",
                                    "Precision": 18,
                                    "Scale": 4,
                                    "Searchable": true,
                                    "AllowNull": true,
                                    "Base": true,
                                    "OAllowNull": true,
                                    "OInUpdate": true,
                                    "OInWhere": true,
                                    "OriginColName": "kcsx",
                                    "SourcePrecision": 18,
                                    "SourceScale": 4
                                },
                                {
                                    "class": "Column",
                                    "Name": "unitid",
                                    "SourceName": "unitid",
                                    "SourceID": 11,
                                    "DataType": "AnsiString",
                                    "Size": 8,
                                    "Searchable": true,
                                    "AllowNull": true,
                                    "Base": true,
                                    "OAllowNull": true,
                                    "OInUpdate": true,
                                    "OInWhere": true,
                                    "OriginColName": "unitid",
                                    "SourcePrecision": 8,
                                    "SourceSize": 8
                                },
                                {
                                    "class": "Column",
                                    "Name": "unitname",
                                    "SourceName": "unitname",
                                    "SourceID": 12,
                                    "DataType": "AnsiString",
                                    "Size": 10,
                                    "Searchable": true,
                                    "AllowNull": true,
                                    "Base": true,
                                    "OAllowNull": true,
                                    "OInUpdate": true,
                                    "OInWhere": true,
                                    "OriginColName": "unitname",
                                    "SourcePrecision": 10,
                                    "SourceSize": 10
                                },
                                {
                                    "class": "Column",
                                    "Name": "kindname",
                                    "SourceName": "kindname",
                                    "SourceID": 13,
                                    "DataType": "AnsiString",
                                    "Size": 30,
                                    "Searchable": true,
                                    "AllowNull": true,
                                    "Base": true,
                                    "OAllowNull": true,
                                    "OInUpdate": true,
                                    "OInWhere": true,
                                    "OriginColName": "kindname",
                                    "SourcePrecision": 30,
                                    "SourceSize": 30
                                }
                            ],
                            "ConstraintList": [],
                            "ViewList": [],
                            "RowList": [
                                {
                                    "RowID": 0,
                                    "Original": {
                                        "goodsid": "100036",
                                        "barcode": "100036",
                                        "goodsname": "秋冬四件套哦",
                                        "pyjm": "",
                                        "gg": "",
                                        "kindid": "12002",
                                        "jj": 100,
                                        "lsj": 430,
                                        "kcxx": 50,
                                        "kcsx": 5,
                                        "unitid": "15",
                                        "unitname": "箱套",
                                        "kindname": "床上用品"
                                    }
                                },
                                {
                                    "RowID": 1,
                                    "Original": {
                                        "goodsid": "100050",
                                        "barcode": "100050",
                                        "goodsname": "天堂伞",
                                        "pyjm": "wrth",
                                        "gg": "",
                                        "kindid": "1",
                                        "jj": 10,
                                        "lsj": 0,
                                        "kcxx": 0,
                                        "kcsx": 0,
                                        "unitid": "15",
                                        "unitname": "箱套",
                                        "kindname": "1111"
                                    }
                                },
                                {
                                    "RowID": 2,
                                    "Original": {
                                        "goodsid": "100054",
                                        "barcode": "100054",
                                        "goodsname": "我们的 哎",
                                        "pyjm": "WMD D7",
                                        "gg": "",
                                        "kindid": "11002",
                                        "jj": 0,
                                        "lsj": 0,
                                        "kcxx": 0,
                                        "kcsx": 0,
                                        "unitid": "18",
                                        "unitname": "公斤",
                                        "kindname": "饮料"
                                    }
                                },
                                {
                                    "RowID": 3,
                                    "Original": {
                                        "goodsid": "100055",
                                        "barcode": "100055",
                                        "goodsname": "娃哈哈纯净水500ML",
                                        "pyjm": "WHHCJS500ML",
                                        "kindid": "11001",
                                        "jj": 0,
                                        "lsj": 0,
                                        "kcxx": 0,
                                        "kcsx": 0,
                                        "unitid": "18",
                                        "unitname": "公斤",
                                        "kindname": "奶粉"
                                    }
                                }
                            ]
                        }
                    ],
                    "RelationList": [],
                    "UpdatesJournal": {
                        "Changes": []
                    }
                }
            }
        },
        {
            "FDBS": {
                "Version": 15,
                "Manager": {
                    "UpdatesRegistry": true,
                    "TableList": [
                        {
                            "class": "Table",
                            "Name": "qryOpen",
                            "SourceName": "tunit",
                            "SourceID": 1,
                            "TabID": 0,
                            "EnforceConstraints": false,
                            "MinimumCapacity": 50,
                            "CheckReadOnly": false,
                            "ColumnList": [
                                {
                                    "class": "Column",
                                    "Name": "unitid",
                                    "SourceName": "unitid",
                                    "SourceID": 1,
                                    "DataType": "AnsiString",
                                    "Size": 4,
                                    "Searchable": true,
                                    "Base": true,
                                    "OInUpdate": true,
                                    "OInWhere": true,
                                    "OInKey": true,
                                    "OriginColName": "unitid",
                                    "SourcePrecision": 4,
                                    "SourceSize": 4
                                },
                                {
                                    "class": "Column",
                                    "Name": "unitname",
                                    "SourceName": "unitname",
                                    "SourceID": 2,
                                    "DataType": "AnsiString",
                                    "Size": 6,
                                    "Searchable": true,
                                    "AllowNull": true,
                                    "Base": true,
                                    "OAllowNull": true,
                                    "OInUpdate": true,
                                    "OInWhere": true,
                                    "OriginColName": "unitname",
                                    "SourcePrecision": 6,
                                    "SourceSize": 6
                                }
                            ],
                            "ConstraintList": [],
                            "ViewList": [],
                            "RowList": [
                                {
                                    "RowID": 0,
                                    "Original": {
                                        "unitid": "11",
                                        "unitname": "个"
                                    }
                                },
                                {
                                    "RowID": 1,
                                    "Original": {
                                        "unitid": "12",
                                        "unitname": "双"
                                    }
                                }
                            ]
                        }
                    ],
                    "RelationList": [],
                    "UpdatesJournal": {
                        "Changes": []
                    }
                }
            }
        }
    ]
}

 主从表查询调用代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
procedure TForm1.btnQueryClick(Sender: TObject);
// 主从表 查询
begin
  var url: TynUrl := TynUrl.Create;
  var serial: TynJsonSerial := TynJsonSerial.Create;
  var send: TMemoryStream := TMemoryStream.Create;
  try
    url.url := Edit1.Text;
    url.command := 'query91';                      // 命令
    url.params.Add('count=2');                     // 查询几个表的数据
    url.params.Add('accountno=1');                 // 帐套号
    url.params.Add('sql=select * from tgoods');    // 查询SQL
    url.params.Add('sql2=select * from tunit');    // 查询SQL2
   // Memo1.Text := IdHTTP1.Post(url.text, send);
    serial.Text := IdHTTP1.Post(url.text, send);
    serial.ReadFDMemTable(0, FDMemTable1);
    serial.ReadFDMemTable(1, FDMemTable2);
  finally
    serial.DisposeOf;
    send.DisposeOf;
    url.DisposeOf;
  end;
end;

  主从表提交调用代码:

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
procedure TForm1.btnPostClick(Sender: TObject);
// 主从表 提交
begin
  var url: TynUrl := TynUrl.Create;
  var serial: TynJsonSerial := TynJsonSerial.Create;
  var send: TMemoryStream := TMemoryStream.Create;
  try
    url.url := Edit1.Text;
    url.command := 'save91';                 // 命令
    url.params.Add('count=2');               // 提交几个表的数据
    url.params.Add('accountno=1');           // 帐套号
    url.params.Add('tablename=tgoods');      // 表名
    url.params.Add('tablename2=tunit');      // 表名2
    url.params.Add('delta=' + serial.FDDeltaToJson(FDMemTable1));   // delta
    url.params.Add('delta2=' + serial.FDDeltaToJson(FDMemTable2));  // delta2
    serial.Text := IdHTTP1.Post(url.text, send);
    if Pos('true', serial.Text) > 0 then
      ShowMessage('数据提交成功')
    else
      ShowMessage('数据提交失败');
  finally
    serial.DisposeOf;
    send.DisposeOf;
    url.DisposeOf;
  end;
end;

  

 

posted @   delphi中间件  阅读(622)  评论(0编辑  收藏  举报
编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?
历史上的今天:
2018-04-01 咏南中间件支持即时通讯
2015-04-01 创建一个EMS 扩展包
2015-04-01 ems server
2015-04-01 redis缓存数据表
点击右上角即可分享
微信分享提示