• 网络学院
  • IT资讯
  • 操作系统
  • 网络技术
  • 软件应用
  • 办公软件
  • 编程技术
  • 网站架设
  • 数据库类
  • 平面设计
  • 多媒体类
  • 游戏资讯
  • 教学论文
  • 认证考试
用AdoDataSet实现数据表的导入导出
  站点:
  • 首 页
  • 最新软件
  • 文章教程
  • 国内软件
  • 国外软件
  • 绿色软件
  • 源码下载
  • 字体下载
用AdoDataSet实现数据表的导入导出
软件发布 用AdoDataSet实现数据表的导入导出
网络软件 系统工具 应用软件 联络聊天 图形图像 多媒体类 行业软件 游戏娱乐 编程开发 安全相关 教育教学 数码软件 绿软下载
热门软件: QQ 瑞星 pplive e话通 木马克星 千千静听 office2000 五笔字根 Photoshop 视频分割
返回文章教程首页 >> 文章首页 >> 编程技术 >> Delphi教程 >> 用AdoDataSet实现数据表的导入导出

用AdoDataSet实现数据表的导入导出

添加时间: 2006-2-25 5:55:05  作者: Delphi教程  阅读次数:123   来源: http://www.d9soft.com

       

  Delphi中的AdoDataSet是支持ADO访问的主要组件,它支持从数据表直接获取数据,支持用SQL语句获取数据。最重要的是,它定义和实现了两个重要的例程:


  procedure LoadFromFile(const FileName: WideString);它从文件中加载数据集。

  procedure SaveToFile(const FileName: String = ''; Format: TPersistFormat = pfADTG);它将数据集保存到文件中。Format确定文件中数据集的保存格式,可以使用的有pfADTG (Advanced Data Tablegram format)、pfXML(Extendable Markup Language)。

  因此AdoDataSet是实现导入导出的良好的基础。

  1.数据表的导出

  导出数据表的操作如下:

  1)打开数据表,设置需要导出的条件;

  2)使用AdoDataSet,调用SaveToFile导出记录;

  下面是一个导出操作的示例(假定导出指定数据表的全部记录)。


  procedure  ExportData(strFileName, strTableName: string);

  begin

  with AdoDataSet1 do

  begin

  Close;

  CommandText := ‘select * from ’ + strTableName;

  Open;

  SaveToFile(strFileName);

  Close;

  end;

  end;

 

  2.数据表的导入

  下面是一个导入操作的示例(假定存在相同主键记录时更新目的表;假定数据表为单主键字段,且其字段类型为字符串型)。


  Procedure  ImportData(strFileName, strTableName, strKeyFieldName: string);

  begin

  with AdoDataSet1 do

  begin

  Close;

  LoadFromFile(strFileName);

  First;

  While not eof do

  begin

  StrKeyValue := FieldByName(strKeyFieldName).AsString;

  If RecordInDest(strTableName, strKeyFieldName, strKeyValue) then

  begin

  AdoDataDest.Close;

  AdoDataSetDest.CommandText := Format(‘select * from %s where %s=%s’,[strTableName, strKeyFieldName, QuotedStr(strKeyValue)]);

  AdoDataSetDest.Open;

  AdoDataSetDest.First;

  AdoDataSetDest.Edit;

  for I:=0 to FieldList.Count-1 do

  AdoDataSetDest.Fields[I] := Fields[I];

  AdoDataSetDest.Post;

  end

 


  else         // 添加记录

  begin

  AdoDataDest.Close;

  AdoDataSetDest.CommandText := Format(‘select * from %s where 1=0’,[strTableName]);  // 获取字段列表

  AdoDataSetDest.Open;

  AdoDataSetDest.Insert;

  for i:=0 to FieldList.Count-1 do

  AdoDataSetDest.Fields[i] := Fields[i];

  AdoDataSetDest.Post;

  end;

  Next;

  end;

  end;

  // 判断指定主键值的记录在表中是否存在

  function RecordInDest(strTableName, strKeyFieldName, strKeyValue: string): boolean;

  begin

  with AdoQuery1 do

  begin

  Close;

  SQL.Clear;

  SQL.Add(Format(‘select count(*) from %s where %s=%s, [strTableName, strKeyFieldName, QuotedStr(strKeyValue)]));

  Open;

  result := Fields[0].AsInteger > 0;

  Close;

  end;

  end;

  如果对数据表的情况进行进一步的考虑,并结合更周密的导入导出方案,比如导入指定字段、导入指定字段、导入指定记录等等,对导入导出过程进行更详细的控制,就可以实现强大的、通用的数据表的导入导出工具。

 

上下文章:

 

上一篇文章: Delphi实用代码:自绘XP风格菜单 下一篇文章: 和md5.asp结果一样的Delphi加密代码

相关文章:

  • 飞速在线看视频 傲盾加速帮你实现速度感受
  • 用端口碰撞技术实现服务器远程管理
  • 如何将excel数据导入oracle中
  • servlet实现oracle中读出文件并显示
  • Sybase和Oracle的互相导入

相关软件:

  • AutoXlsTable(Excel表格导入AutoCAD) V2.52
  • DLL导出函数查看器 V1.3
  • 修改IIS的BANNER实现操作系统版本的隐藏(PDF)
  • VB.NET面向对象的实现(CHM)
  • 基于asp.net的数据表显示控件DTable V7.0

 

快速导航

  • 网络学院
  • 精品汇聚
  • 字体下载
  • 教程下载
  • ASP源码
  • PHP源码
  • Net源码
  • JSP 源码

编程技术分类导航

  • ASP & ASP.NET教程
  • PHP教程
  • JSP教程
  • C/C++教程
  • VB & VB.NET教程
  • VC教程
  • Delphi教程
  • BCB教程
  • VFP教程
  • PB教程
  • JAVA教程
  • XML教程
  • C#教程
  • CGI教程

本类经典文章推荐

  • Delphi的两个实用技巧(1)播放Flash
  • Delphi的两个实用技巧(2)巧用Wind...
  • delphi实例编程之--制作可随处拖放...
  • 关于VisiBroker For Delphi的使用...
  • 关于VisiBroker For Delphi的使用...
  • 关于VisiBroker For Delphi的使用...
  • 在线播放器DIY
  • Delphi让你发送Flash电子邮件
  • 在窗口标题区添加按钮
  • 用Delphi 6编程实现自动标注汉语拼...

Delphi教程阅读排行

  • Delphi7从入门到精通之历数Delphi...
  • Delphi的两个实用技巧(1)播放Flash
  • Delphi7从入门到精通之认识Delphi...
  • delphi实例编程之--制作可随处拖放...
  • Delphi控件,我们也可以(1)
  • Delphi的两个实用技巧(2)巧用Wind...
  • 在线播放器DIY
  • Delphi控件,我们也可以(2)
  • Spcomm串口控件的例程
  • 用Delphi + DirectX开发简单RPG游...

编程技术阅读总排行

  • VB入门教程之一
  • Java连接数据库实例
  • 第二章 PowerBuilder 入门之创建新...
  • VC++之List Box/Check List Box控...
  • 第一章 什么是PowerBuilder
  • VC++ List Ctrl控件
  • VC++ Combo Box/Combo Box Ex控件
  • 学C++不得不看的一篇文章
  • VB入门教程之二
  • VC++之Button控件

广告位置

字母检索 A B C D E F G H I J K L M N O P Q R S T U V W X Y Z 回到顶部

关于我们 | 版权声明 | 免责条款 | 广告联系 | 软件发布 | 下载帮助 | 下载排行 | 网站地图 | 特别鸣谢 | 友情连接

copyright; 2005-2008 D9soft.com 第九软件网 版权所有