Delphi

本类阅读TOP10

·分布式网络考试系统原型分析及实现
·游戏外挂设计技术探讨①
·使用HOOK随心监视Windows
·Delphi 水晶报表打包解决
·试题库开发中非文本数据的处理
·如何将几个DBGRID里的内容导入同一个EXCEL表中....的问题
·如何使用Delphi设计强大的服务器程序
·工人线程中关闭窗体的实现
·用DLL方式封装MDI子窗体。
·支持XP下托盘栏气球提示的托盘单元

分类导航
VC语言Delphi
VB语言ASP
PerlJava
Script数据库
其他语言游戏开发
文件格式网站制作
软件工程.NET开发
手册中关于怎样使用TQuery 的误导

作者:未知 来源:月光软件站 加入时间:2005-2-28 月光软件站

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的时候要注意根据实际情况选择适当的方法, 不要被手册误导。

 




相关文章

相关软件