在一个程序中你会多次查询数据库的,因此在你写的查询方法中定义一个局部的ADOQuery就可以了,它返回一个数据集_RecordSet。最简单的应用如下:
function GetData: _RecordSet; //获取一张表中的全部数据(_RecordSet是一种类型)
var
TaADOQ: TADOQuery; //声明
begin
TaADOQ:= TADOQuery.Create(nil); //创建
TaADOQ.Connection := ADOCon; //意思是ADOQuery连接数据库时用ADOConnection建立好的连接。
TaADOQ.SQL.Text := 'select * from TableName';
TaADOQ.Open; //执行查询,如果是增、删、改则用pADOQ.ExecSQL
Result := TaADOQ.Recordset; //函数返回结果
end;
接下来是怎样用这个返回的结果集。
在用的地方再次声明一个ADOQuery,用于接收这个返回的结果集。(当然也可以直接使用)
TaADOQ: TADOQuery;
TaItem: TListItem; //一个listview,用于显示记录
begin
TaADOQ:= TADOQuery.Create(nil);
TaADOQ.RecordSet := GetData; //将结果集赋给pADOQ
if TaADOQ.RecordCount <= 0 then exit; //结果集为空,退出
TaADOQ.First ; //将游标放到结果集的第一条记录
while not ADOQuery.Eof do //开始循环结果集(当该条记录不是最后一条时)
begin
TaItem:= lvMain.Items.Add; //在listview中加一行
TaItem.Caption := Trim(ADOQuery.FieldByName('patid').AsString);
TaItem.SubItems.Add(ADOQuery.FieldByName('patname').AsString);
TaADOQ.Next; //游标移动到记录的下一条
end;
end;
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现