过程:先Edit,然后SetFieldValue,接着Update,最后MoveNext

本文详细介绍了使用VBA操作Excel数据库的过程,包括如何通过CDaoRecordset类进行数据记录的编辑、更新等操作,并探讨了优化操作流程的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

过程:先Edit,然后SetFieldValue,接着Update,最后MoveNext

CDaoDatabase database;
...

database.Open (sFile,false,false,"Excel 5.0");
CDaoRecordset recset(&database);
...

recset.MoveNext ();//跳过若干条记录

recset.MoveNext ();
  
for(int j=1;j<=i;j++)
{
    TCHAR msg[255]="";
    sprintf(msg,"%d",j);
       recset.Edit ();
    recset.SetFieldValue ("A1",msg);
    recset.SetFieldValue ("B1",data.GetAt (j-1));
    recset.Update ();
    recset.MoveNext ();
//   Sleep(200);

}
recset.Close ();
database.Close();

之前,我尝试在某个MoveNext后立即进行SetFieldValue操作,可是失败了:

---------------------------
excel
---------------------------
在不使用 AddNew 或 Edit 的情况下,更新 (Update) 或取消更新 (CancelUpdate)。
---------------------------
确定  
---------------------------

然后通过搜索,发现要SetFieldValue,需要先Edit一下,完成后,要Update。于是成功了。

刚才想优化一下。现在的代码,每次SetFieldValue,都要先Edit然后Update,那么我能不能从第一个MoveNext开始之前,就先Edit,在最后一个的时候再Update呢?这样似乎能省不少时间!

结果,失败了!

原来,这个recset的SetFieldValue是针对单条、当前数据进行操作的,所以,要修改,必须对当前该条数据先进行Edit,修改后,再Update。

释然!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值