delphi ADOQuery 与 DBGRID 更新问题(弱问)

拖了三个控件,ADOQuery1,DataSource1,DBGrid1.当我用ADOQuery1.Open执行SQL:"select*frommytable"后,DBG... 拖了三个控件, ADOQuery1 , DataSource1, DBGrid1.
当我用 ADOQuery1.Open 执行 SQL: "select * from mytable" 后, DBGrid1 自动更新了.
当我用 ADOQuery1.Open 执行 SQL: "select * from mytable where xxx" 后, DBGrid1 也自动更新了. 但是我不想把这一次的查询结果显示出来, 能否控制什么时候显示数据.

前提是我只想用同一个 ADOQuery1.
展开
 我来答
whlibk
2010-01-20 · 超过31用户采纳过TA的回答
知道答主
回答量:130
采纳率:0%
帮助的人:88.2万
展开全部
可以啊,你在第二次查询之前做
DBGrid1.DataSource:='';

查询之后再提示是否显示新数据?是
DBGrid1.DataSource:='DataSource1';
否再
select * from mytable
DBGrid1.DataSource:='DataSource1';

不过呢,在你显示新数据前,DBGrid1是没有数据显示的.
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
maodrc
2010-01-21 · TA获得超过3289个赞
知道小有建树答主
回答量:1090
采纳率:79%
帮助的人:1183万
展开全部
可以不用DBgrid了.用Stringgrid ,自己手动将值从AdoQuery的Fields 中取出,循环赋值给Stringgrid相应的单元即可 (Stringgrid.Cells[])
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
yueyun889
2010-01-20 · TA获得超过725个赞
知道小有建树答主
回答量:539
采纳率:0%
帮助的人:768万
展开全部
因为DateSource是数据感知控件,所以一旦和它连接的DateSet数据集发生改变,DateSource也会随之而变。一旦把dateSource的数据库去掉,DBGrid必然也显示不出数据(使用DateSet的DisableControls勉强可以实现这个功能,但是后续还是会有很多麻烦),这种结果并不是我们想得到的。如果你想界面只用一个ADOQuery,那么就动态创建一个TADOQuery,专门用来查询的。
procedure TForm1.btn2Click(Sender: TObject);
var
strQry: TADOQuery;
begin
strQry := TADOQuery.Create(nil);
strQry := Query1;//复制Query1的连接属性,或者自己设置: strQry.Connection := con1;
strQry.SQL.Text := 'SELECT TOP 10 * FROM S220';
strQry.Open;
end;
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式