REST CRUD
REST CRUD
rest api 支持任何语言、前后端调用。
使用APIPost工具测试。
查询
apipost查询
delphi查询
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 FDMemTable1.AppendRecord([row.Unitid, row.Unitname]); FDMemTable1.First; FDMemTable1.EnableControls; end; |
新增
apipost新增
delphi新增
1 2 3 4 5 6 7 8 9 10 | procedure TForm1.Button1Click(Sender: TObject); //新增 begin SetLength(data.rows, 1); data.rows[0].Unitid := '1' ; data.rows[0].Unitname := '新增' ; crud.resource := 'danwei' ; crud.data := data; crud.insert; end; |
修改
apipost修改
delphi修改
1 2 3 4 5 6 7 8 9 10 | procedure TForm1.Button3Click(Sender: TObject); //修改 begin SetLength(data.rows, 1); data.rows[0].Unitid := '1' ; data.rows[0].Unitname := '修改' ; crud.resource := 'danwei' ; crud.data := data; crud.update; end; |
删除
apipost删除
delphi删除
1 2 3 4 5 6 7 8 9 | procedure TForm1.Button7Click(Sender: TObject); //删除 begin SetLength(data.rows, 1); data.rows[0].Unitid := '1' ; crud.resource := 'danwei' ; crud.data := data; crud.delete; 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 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 | procedure TRESTdanwei.select2( 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 tables: TTables<Tdanwei, Tdanwei>; //2个表 SetLength(tables.table1.rows, db.qry.RecordCount); SetLength(tables.table2.rows, db.qry.RecordCount); var i: Integer := 0; db.qry.First; while not db.qry.Eof do begin tables.table1.rows[i].unitid := db.qry.FieldByName( 'unitid' ).AsString; tables.table1.rows[i].unitname := db.qry.FieldByName( 'unitname' ).AsString; tables.table2.rows[i].unitid := db.qry.FieldByName( 'unitid' ).AsString; tables.table2.rows[i].unitname := db.qry.FieldByName( 'unitname' ).AsString; db.qry.Next; Inc(i); end; res.Send(TSerial<TTables<Tdanwei, Tdanwei>>.json(tables)); except on E: Exception do begin res.Send(error(E.Message)); writelog( 'TRESTdanwei.select2()' + E.Message); end; end; finally pool.Unlock(db); end; end; |
本文来自博客园,作者:{咏南中间件},转载请注明原文链接:https://www.cnblogs.com/hnxxcxg/p/17548376.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
2016-07-12 DATASNAP高效的FIREDAC数据序列和还原
2016-07-12 datasnap中间件如何控制长连接的客户端连接?
2016-07-12 FDMemTable三层提交数据总是不成功的原因