我的未来

我的未来
随笔 - 9, 文章 - 0, 评论 - 1, 阅读 - 5145

Delphi 数据库查询(TADOQuery)

Posted on   MKing  阅读(984)  评论(0编辑  收藏  举报

在一个程序中你会多次查询数据库的,因此在你写的查询方法中定义一个局部的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,用于接收这个返回的结果集。(当然也可以直接使用)

复制代码
var
    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;
复制代码
编辑推荐:
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示