MSADO相关问题

来源:互联网 发布:淘宝仓库里的宝贝在哪 编辑:程序博客网 时间:2024/05/18 17:27

下面是一段伪码:

commandstring = “select * from student ”

pCommand->CommandText = commandstring;

pRecordset = pCommand->Execute(NULL,NULL,adCmdText);


while(!pRecordset->adoEOF)

{

    long buflen = pRecordset->GetFields()->GetItem("xx")->ActualSize;


   _variant_t buffer =  pRecordset->GetFields()->GetItem("xx")->GetChunk(buflen);


  // long buflen = pRecordset->GetFields()->GetItem("xx")->ActualSize;


 //  _variant_t buffer =  pRecordset->GetFields()->GetItem("xx")->GetChunk(buflen);


}


如果把注释打开,也就是while中执行两遍相同的代码,则第二遍的buflen的值为0,这是让我苦思不得其解的地方,请各位看官,指教指教。


论坛里我也发了提问 http://bbs.csdn.net/topics/390491466   

有位前辈是这么解释的:GetChunk有点像读文件的Read函数,调用一次后文件Position已经改变了,再Read就不是原来的值了。
调用MoveXXXX函数后会重置。

原创粉丝点击