利用ado读取excel的问题

利用ado读取excel的问题

ID:40554843

大小:14.90 KB

页数:3页

时间:2019-08-04

利用ado读取excel的问题_第1页
利用ado读取excel的问题_第2页
利用ado读取excel的问题_第3页
资源描述:

《利用ado读取excel的问题》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、利用ADO操作Excel文件今天花时间研究了一下ADO操作Excel文件的问题,跟大家分享一下:首先利用Excel2003创建了一个名为Demo.xls的文件,内容如下:NameAgeTY12TZL15然后打开VC,创建一个命令行应用程序。然后如一般的ADO程序一样编写相应代码,只是注意打开数据库的代码如下写:m_pConnection->Open("Provider=Microsoft.Jet.OLEDB.4.0;DataSource=Demo.xls;ExtendedProperties=/"Excel8.0;HDR=No;IMEX

2、=1/"","","",adModeUnknown);  注意一下HDR,如果后面是No的话,表示ADO将不把你Excel文件的第一行作为字段名(此时使用默认字段名:F1,F2。。以此类推,当然也可以用(LPCTSTR)m_pRecordset->GetFields()->GetItem((_variant_t)zz)->Name之类的代码来获得相应的字段名)。否则如上Excel文件的字段名将是Name与Age。另外是IMEX,如果设置了"IMEX=1;"则通知驱动程序始终将“互混”(数字,日期,字符串等)数据列作为文本读取,同时这个选

3、项有可能影响到excel表格拒绝写操作,也就是说,如果我们要求写入excel的话,这个选项不能被设置。接下来是打开记录集,代码如下(注意一下表名的写法):m_pRecordset->Open("select*from[Sheet1$]",_variant_t((IDispatch*)m_pConnection,true),adOpenDynamic,adLockOptimistic,adCmdUnknown);知道了字段名,打开了数据库跟记录集,随后的操作就跟普通ADO的操作一样了:读取操作:while(!m_pRecordset->a

4、doEOF){ _variant_tvar=m_pRecordset->GetCollect("Name"); if(var.vt!=VT_NULL)  _bstr_tstrName=(LPCSTR)_bstr_t(var); var=m_pRecordset->GetCollect("Age"); if(var.vt!=VT_NULL)  _bstr_tstrAge=(LPCSTR)_bstr_t(var); stringstrMid=strName+"-->"+strAge; cout<

5、m_pRecordset->MoveNext();}插入操作:m_pRecordset->AddNew();m_pRecordset->PutCollect("Name",_variant_t("zz"));m_pRecordset->PutCollect("Age",_variant_t("23"));m_pRecordset->Update();更新操作:m_pRecordset->MoveFirst();m_pRecordset->PutCollect("Name",_variant_t("zz"));m_pRecordset->

6、Update();删除操作:不支持!这也是感到很遗憾的地方。好在我们可以通过执行update[Sheet1$]setName=NULL,Age=NULLwhereName='zz' 之类的SQL语句来实现类似功能。当然,你要知道的是,这一行并没有真正删除掉,所以通常在select的时候要进行一定的筛选,例如:select*from [Sheet1$]whereNameisnotNULL;其它注意事项:如果通过执行SQL语句的方法完成数据插入与更新操作,需要注意所有的字段,包括数字,都要按文本来处理,否则会报类型不正确的错

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。