中国IT动力,最新最全的IT技术教程
最新100篇 | 推荐100篇 | 专题100篇 | 排行榜 | 搜索 | 在线API文档 | 网通镜像
首 页 | 程序开发 | 操作系统 | 软件应用 | 图形图象 | 网络应用 | 精文荟萃 | 教育认证 | 硬件维护 | 未整理篇 | 站长教程
ASP JS PHP工程 ASP.NET 网站建设 UML J2EESUN .NET VC VB VFP 网络维护 数据库 DB2 SQL2000 Oracle Mysql
服务器 Win2000 Office C DreamWeaver FireWorks Flash PhotoShop 上网宝典 CorelDraw 协议大全 网络安全 微软认证
硬件维护  CPU  主板  硬盘  内存  显卡  显示器  键盘鼠标  声卡音箱  打印机  机箱电源  BIOS  网卡  C#  Java  Delphi  vs.net2005
  当前位置:> 程序开发 > 编程语言 > Delphi > 数据库
手册中关于怎样使用TQuery的误导
作者:ghj1976 时间:2001-10-29 10:37 出处:互联网 责编:chinaitpower
              摘要:手册中关于怎样使用TQuery的误导

Q:手册中关于怎样使用TQuery 的误导

A:用Delphi开发数据库时经常会用到TQuery, 手册中有很多关于它的例子, 大致结构如下:

Query1.Close;
Query1.ParamByName('ID').AsString := '001';
Query1.Open;
String := Query1.FieldByName('ID').AsString;

很多用户根据这段例子开发时会遇到速度慢, 资源耗用多, 甚至引发资源不足的异常。 这是为什么呢, 其实是手册的例子有些片面, 误导了大家。

Delphi有一个重要的特性是DB aware, 把DBGrid与Query连接在一起, Query的结果集就会自动的显示在DBGrid中。 为了保证DBGrid总显示查询结果, 需要Query总保持Active。 当修改Query的查询条件时, 先关闭Query, 修改完查询条件以后再打开它。 这就是上面代码的含义。

问题是,当Query不和DB aware组件连接时, 比如在计算字段的事件中取其它表的内容, 应该怎样写代码。 这时候不需要让Query保持Active, 相反, 为了减少不必要的浪费, 应该是保持DeActive。 所以代码应该如下:

Query1.ParamByName('ID').AsString := '001';
Query1.Open;
String := Query1.FieldByName('ID').AsString;
Query1.Close;

您在使用Query的时候要注意根据实际情况选择适当的方法, 不要被手册误导。

 

关闭本页
 
首页 | 投资与合作 | 服务条款 | 隐私政策 | 收藏本站 | 设为首页 | 新用户注册 | 免责声明 | 使用帮助
Copyright ©2005-2008 chinaitpower.com All rights reserved. www.chinaitpower.com 版权所有