既然是说Delphi中的SQL使用,肯定离不开TDataSet派生出来的DataSet控件(应该说类比较确切些),这里我说的DataSet只是一个大类的称呼,并不是特指实际的TDataSet。在众多控件中其实可以根据如何操作数据分为两类。 其中一类是TTable,TADOTable等控件,这些控件只要获得数据链接和表名就能获得数据;另外一种是TQuery,TADOQuery等需要程序员指定SQL才能进行数据操作。 可能有人会说TADODataSet,ADOStoredProc不用“硬性”指定SQL,不过我还是习惯把这些控件归入后者。
    对于上文提到的第一类控件,这些控件在数据操作过程中可以自动生成特定的SQL语句并且执行。因为不需要程序员干预数据操作的SQL,在显示数据列表的场合,使用起来比较方便。但是方便的东西决定了它的灵活性与适用性受到很大的限制。先来看看Table控件(后文如果没有特别指出的话,都是借代这一类控件)是如何提取数据,它是怎样工作的。Table控件属性TableName指定了要操作的表,在Table.Open的时候,Table会生成一条Select * From XXXTable的SQL语句,并发送到后台数据服务器执行。从这个语句可以看到Table是把整个表的数据从服务端提取到本地,在数据量比较庞大的时候,结果时候是可想而知的。其中BDE里面可以设置缓冲区,ADO可以设置CacheSize,MaxRecord来改善效率。但用户很多时候并不需要操作所有的数据,而是某些符合条件的数据,所以这种提取数据的方式欠妥。另外可以通过SQL Moniter看一下Table控件是如何更新数据的。
    譬如 :
       Table.Edit;
           Table.Fields[0].AsInteger:=0;
           Table.Post;
可以从SQLMoniter看到 Update XXXX Set  myField=0 Where xxxxxxx。其中where后面的部分就是Table操作的那条记录的标识,一般就是这个表的主键。对应新增和删除操作,Table都能自动生成相应操作。这种特性在后面提到的Query也具备,不过注意的问题会多一些,在此先不讨论。

转载于:https://www.cnblogs.com/Byeah/archive/2004/06/21/3162429.html

Delphi数据库开发之TTable篇1相关推荐

  1. 跟着王进老师学开发之C#篇第五季:图书管理系统-王进-专题视频课程

    跟着王进老师学开发之C#篇第五季:图书管理系统-2659人已学习 课程介绍         本季视频通过完整的案例介绍了图书管理系统的开发,包含了数据库的设计.界面设计.代码实现等等,本系统的模块包含 ...

  2. 跟着王进老师学开发之Python篇第一季:基础入门篇-王进-专题视频课程

    跟着王进老师学开发之Python篇第一季:基础入门篇-2859人已学习 课程介绍         本季课程首先对Python简要介绍,然后演示如何搭建Python的开发环境,以及如何在IDE中调试Py ...

  3. 视频教程-跟着王进老师学开发之Python篇第一季:基础入门篇-Python

    跟着王进老师学开发之Python篇第一季:基础入门篇 教学风格独特,以学员视角出发设计课程,难易适度,重点突出,架构清晰,将实战经验融合到教学中.讲授技术同时传递方法.得到广大学员的高度认可. 王进 ...

  4. Jmeter Kafka插件开发之Sampler篇

    Jmeter Kafka插件开发之Sampler篇 背景:在项目中经常需要往kafka里面写数据,并拿生成的数据执行后续的操作,并且有些接口中也需要用到kafka里的数据,小编使用JMeter做接口测 ...

  5. 微信开发 ━━ 微信商户v3微信支付H5方式开发之php篇

    native方式开发纪要:<微信开发 ━━ 微信商户native方式支付v3开发之php篇> 一.流程 流程是必须要弄懂的,弄懂之后遇到问题也能知道出在哪里. 官方说明:<H5支付统 ...

  6. java jcombobox 样式_Swing开发之JComboBox篇

    JList和ComboBox很相似,因为这两个组件都显示一个项列表.因此,它们都有扩展ListModel接口的模型.而且,这两个组件都有绘制器,这些绘制器通过实现ListCellBenderer接口来 ...

  7. 视频教程-跟着王进老师学开发之C#篇:基础语法-C#

    跟着王进老师学开发之C#篇:基础语法 教学风格独特,以学员视角出发设计课程,难易适度,重点突出,架构清晰,将实战经验融合到教学中.讲授技术同时传递方法.得到广大学员的高度认可. 王进 ¥208.00 ...

  8. 跟着王进老师学开发之C#篇:基础语法-王进-专题视频课程

    跟着王进老师学开发之C#篇:基础语法-10520人已学习 课程介绍         本次课程是初级课程,只要熟悉计算机的基本应用和操作,都可以完成本次课程学习.本课程深入浅出的介绍了C#语言的基本语法 ...

  9. 大数据开发之Hive篇12-Hive正则表达式

    备注: Hive 版本 2.1.1 文章目录 一.Hive 正则表达式概述 1.1 字符集合: 1.2 边界集合: 1.3 重复次数集合: 1.4 组合操作符: 1.5 匹配操作符: 1.6 转义操作 ...

最新文章

  1. 13.angular时间
  2. 理解java中的两种接口
  3. 独家|深度学习训练和推理之间有什么差异?
  4. 互联网思维-产品思维(2)
  5. laravel上传文件报错:413 Request Entity Too Large
  6. SpringBoot 源码解析 (一)----- SpringBoot核心原理入门
  7. 7.3.7 - 并发多线程 死锁和递归锁
  8. 深度干货 | 多维分析中的 UV 与 PV
  9. 数字经济的核心是对大数据_大数据崛起为数字世界的核心润滑剂
  10. Spark Streaming的工作机制
  11. 牛客寒假算法基础集训营2 处女座的测验(一) (数论+构造)
  12. 手把手教你玩华为eNSP模拟器
  13. Python爆力破解rar密码并对比多线程的效率
  14. vue 下载文件 前后端代码亲测有效
  15. 重装战姬电脑版模拟器怎么玩
  16. Perl读取文件信息
  17. word文件退出只读模式
  18. KVM虚拟化的概述和部署
  19. 【前端】你真的理解JavaScript中的变量和数据类型吗
  20. 电脑连接无线路由上不了网 连接手机热点却可以上网

热门文章

  1. safari java插件故障_safari flash插件故障怎么办 mac safari flash插件故障解决方法
  2. UI设计不够高端?这5个小技巧可以试试
  3. python学习第四课
  4. MaxCompute助力OSS支持EB级计算力
  5. Windows Server 2008 R2安装子域控制器
  6. Android程序完全退出的三种方法
  7. 开源代码hosting openfoundryfrom tw
  8. JavaScript写XML
  9. AS1.0(2.0)中的XML示例
  10. sql server日志占用空间过大的问题