超难解决的逻辑错误问题? 急急急

超难解决的逻辑错误问题? 急急急 Delphi / Windows SDK/API
http://www.delphi2007.net/DelphiDB/html/delphi_20061222173752156.html
 
  我的程序面板上放有:DBGrid,AdoQuery等,还有“下一条记录”,“上一条记录”,“删除当前记录”等按扭,程序启动时DBGrid为空,此时点击上面任何一按扭,程序报错退出。  
  以“删除”按纽为例,我的程序如下:  
  procedure   TForm1.Button5Click(Sender:   TObject);  
  begin  
  adoquery1.open;                                                                        
    if   adoquery1.RecordCount=0   then                                        
      MessageBox(0,'SetCommMask   Error   !','Notice',MB_OK)  
    else  
  if   Application.MessageBox('是否删除当前记录?','提示',mb_yesno)=id_yes   then  
  ADOQuery1.Delete;  
  end;  
  为了执行是否adoquery1.RecordCount=0,必须adoquery1.open,但是当   adoquery1.RecordCount=0时,Adoquery1.SQL.Text:=''此时就不能和数据库想连,当然就不能去计算Recordcount,想了一天了,脑袋都大了,哪位大哥帮帮我啊,感激涕零。  
  如果问题没搞清,QQ:110546987在线等到,bearzmc@163.com.谢谢

没看明白说得是什么?

procedure   TForm1.Button5Click(Sender:   TObject);  
  begin  
  adoquery1.close;  
  adoquery1.sql.clear;  
  adoquery1.add('select   *   from   table   where   .....');  
  adoquery1.open;                                                                        
    if   adoquery1.RecordCount=0   then                                        
      MessageBox(0,'SetCommMask   Error   !','Notice',MB_OK)  
    else  
  if   Application.MessageBox('是否删除当前记录?','提示',mb_yesno)=id_yes   then  
  begin  
    ADOQuery1.close;  
    ADOQuery1.sql.clear;  
    ADOQuery1.sql.add('delete   table   where   ....');  
    ADOQuery1.execsql;  
  end;  
  end;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值