delphi orm

delphi orm

以计量单位为例。

1)定义单位data-model,实际项目,为了加快开发速度,会使用工具从数据表自动生成data-model。

 生成的计量单位data-model

1
2
3
4
5
6
7
8
9
10
11
12
13
unit danwei.model;
/// <author>cxg 2023-8-30</author>
interface
 
type      //定义 数据模型(data-model)
  Tdanwei = record
    unitid: string;
    unitname: string;
  end;
 
implementation
 
end.

2)以服务端查询为例

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
procedure TRESTdanwei.select(const req: TRequest; const res: TResponse);
begin
  var pool: TDBPool := GetDBPool('1');
  var db: TDB := pool.Lock;
  try
    try
      var where: string;
      if req.Body <> nil then
        where := TEncoding.UTF8.GetString(TBytesStream(req.Body).Bytes);
      var sql: string;
      if where = '' then
        sql := 'select * from tunit'
      else
        sql := 'select * from tunit where ' + where;
      db.select(sql);
      var data: TData<Tdanwei>; //泛型data-model
      SetLength(data.rows, db.qry.RecordCount);
      var i: Integer := 0;
      db.qry.First;
      while not db.qry.Eof do //将dataset数据填充进泛型data-model
      begin
        data.rows[i].unitid := db.qry.FieldByName('unitid').AsString;
        data.rows[i].unitname := db.qry.FieldByName('unitname').AsString;
        db.qry.Next;
        Inc(i);
      end;
      res.Send(TSerial<TData<Tdanwei>>.json(data)); //序列data-model为json
    except
      on E: Exception do
      begin
        res.Send(error(E.Message));
        writelog('TRESTdanwei.select()' + E.Message);
      end;
    end;
  finally
    pool.Unlock(db);
  end;
end;

3)以delphi客户端查询为例

var data: TData<Tdanwei>;  //泛型data-model
var crud: TRest<TData<Tdanwei>>; //泛型rest CRUD接口

1
2
3
4
5
6
7
8
9
10
11
12
13
procedure TForm1.Button5Click(Sender: TObject);
//查询
begin
  crud.resource := 'danwei'//资源=计量单位
  crud.where := 'unitid like ''1%''';
  data := crud.select;
  FDMemTable1.DisableControls;
  FDMemTable1.EmptyDataSet;
  for var row: Tdanwei in data.rows do //将泛型data-model数据填充进内存表dataset
    FDMemTable1.AppendRecord([row.Unitid, row.Unitname]);
  FDMemTable1.First;
  FDMemTable1.EnableControls;
end;

4)跨平台、语言的客户端以apipost工具查询为例

 

  

 

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