DELPHI模板编程
DELPHI模板编程
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 | procedure TCRUD<T>.execsql(OnTableModel: TTableModel); //执行事务性SQL begin if req.Body = nil then Exit; var pool: TDBPool := GetDBPool(dbid); //database pool db := pool.Lock; try try table := serialize.TSerial<TTable<T>>.unjson(TStream(req.Body)); //json string--->record db.startTrans; //开启事务 for var i: Integer := 0 to High(table.rows) do begin db.qry.Close; db.qry.SQL.Clear; db.qry.sql.add(sql); OnTableModel(db, table, i); //set field value db.qry.ExecSQL; end; db.commitTrans; //提交事务 res.Send(success); except on E: Exception do begin db.rollbackTrans; //回滚事务 res.Send(error(E.Message)); WriteLog(func + E.Message); end; end; finally pool.Unlock(db); end; end; procedure TCRUD<T>.open(OnTableModel: TTableModel); //查询 begin var pool: TDBPool := GetDBPool(dbid); db := pool.Lock; try try var where : string ; //where条件 if req.Body <> nil then where := TEncoding.UTF8.GetString(TBytesStream(req.Body).Bytes); var lsql: string ; if where = '' then //拼SQL查询命令 lsql := sql else lsql := sql + ' where ' + where ; db. select (lsql); //查询 SetLength(table.rows, db.qry.RecordCount); //记录条数 var i: Integer := 0; db.qry.First; //dataset--->record while not db.qry.Eof do begin OnTableModel(db, table, i); //set field value db.qry.Next; Inc(i); end; res.Send(TSerial<TTable<T>>.json(table)); //send json string except on E: Exception do begin res.Send(error(E.Message)); writelog(func + E.Message); end; end; finally pool.Unlock(db); end; end; |
本文来自博客园,作者:{咏南中间件},转载请注明原文链接:https://www.cnblogs.com/hnxxcxg/p/17908794.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
2020-12-17 datasnap+msgpack