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

 

过程:先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。

释然!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这个错误是因为在代码中调用了一个名为D.setFieldValue的函数,但是该函数并不存在,所以报错了。这个错误通常是由于函数名拼写错误或者函数未定义导致的。要解决这个问题,你需要检查代码中是否正确引用了该函数,并确保函数名的拼写是正确的。如果函数确实不存在,你需要定义该函数或者找到正确的函数来替代它。引用\[2\]中提到了在使用promise时捕获错误的方法,你可以尝试在调用D.setFieldValue的地方使用catch方法来捕获错误并进行处理。例如:D.setFieldValue().catch((error) => { console.log('error: ' + error); }); 这样可以避免Uncaught (in promise) TypeError错误的出现。 #### 引用[.reference_title] - *1* *3* [报`Uncaught (in promise)`错误解决办法](https://blog.csdn.net/weixin_46721670/article/details/127054288)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [Web前端-Vue控制台报错:Uncaught (in promise) TypeError:](https://blog.csdn.net/MinggeQingchun/article/details/120003750)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值