45IT.COM- 电脑学习从此开始!
DIY硬件教程攒机经验装机配置
设计Photoshop网页设计特效
系统注册表DOS系统命令其它
存储主板显卡外设键鼠内存
维修显卡CPU内存打印机
WinXPVistaWin7unix/linux
CPU光驱电源/散热显示器其它
修技主板硬盘键鼠显示器光驱
办公ExcelWordPowerPointWPS
编程数据库CSS脚本PHP
网络局域网QQ服务器
软件网络系统图像安全
页面导航: 首页 > 设计学院 > 网络编程 > 数据库 >

批处理dbgrid提示List index out of bounds的解决

电脑软硬件应用网 45IT.COM 时间:2011-11-25 09:38 作者:佚名

处理dbgrid多行选择数据出错。提示List index out of bounds (1)。

步调试时,在s:=DataModule2.ADOQuery1.fieldbyname('bookname').AsString;这句出现的错误。

如果虚线中的内容不加入则正常,请诸位看看问题在哪?


procedure TForm1.Button2Click(Sender: TObject);
var
i:integer;
bookmarklist:tbookmarklist;
bookmark:tbookmarkstr;
s:string;
begin
bookmark:=DataModule2.ADOQuery1.Bookmark;
try
listbox1.Clear;
bookmarklist:=tbookmarklist.Create(nil);
bookmarklist:=dbgrid1.SelectedRows;
for i:=0 to bookmarklist.Count-1 do
begin
DataModule2.ADOQuery1.Bookmark:=bookmarklist[i];
s:=DataModule2.ADOQuery1.fieldbyname('bookname').AsString;
listbox1.Items.Add(s); //这行用于测试能否得到选定行的数据

//----------下面的数据处理语句加上则出错----------
DataModule2.ADOQuery1.CLose;
DataModule2.ADOQuery1.SQL.Clear;
DataModule2.ADOQuery1.SQL.Add('update book set bookmoney = 666 where bookname=:s');
DataModule2.ADOQuery1.execSQL;
//----------

end;
finally
DataModule2.ADOQuery1.bookmark:=bookmark;
end;
end;
----------------------------------------------
--------------------------------------------------------------------------------

//----------下面的数据处理语句加上则出错----------
DataModule2.ADOQuery1.CLose;
DataModule2.ADOQuery1.SQL.Clear;
DataModule2.ADOQuery1.SQL.Add('update book set bookmoney = 666 where bookname=:s');
DataModule2.ADOQuery1.execSQL;

加上这句后,你的原来的数据集已经丢失了。再去访问原来的指针肯定会出错的。因为已经不存了。

解决方法,再增加一个 adoquery 来处理更新。

顶一下
(0)
0%
踩一下
(0)
0%
------分隔线----------------------------
无法在这个位置找到: baidushare.htm
发表评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
评价:
表情:
验证码:点击我更换图片
你可能感兴趣的文章
推荐知识