佚名通过本文主要向大家介绍了ado recordset,ado recordset open,data1.recordset,recordset,adodb.recordset等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com
问题: MFC中Ado Data Control获取Recordset的问题
描述:
执行到m_pRS->GetFieldValue(1,value);就出错了。断点调试之,发现QueryInterface没有执行成功,没有得到控件中的recordset。
哪位达人使用过这个控件,请赐教一二,不胜感激!
ps:ado data control里是设置过的,绑定到datagird是能显示数据的
解决方案1:
试下。
描述:
vs2008中创建了一个基于对话框的MFC工程,窗体中添加了一个ado data control控件,在其willmove事件中添加了如下代码:
void CMFCChartDlg::WillMoveAdodc1(long adReason, long* adStatus, LPDISPATCH pRecordset)
{
CRecordset *m_pRS;
m_pRS=new CRecordset();
pRecordset->QueryInterface(IID_IDispatch, (void **)m_pRS);
CString value;
if( adReason != 10 )
{
m_pRS->GetFieldValue(1,value);
MessageBox(value);
}
}
执行到m_pRS->GetFieldValue(1,value);就出错了。断点调试之,发现QueryInterface没有执行成功,没有得到控件中的recordset。
哪位达人使用过这个控件,请赐教一二,不胜感激!
ps:ado data control里是设置过的,绑定到datagird是能显示数据的
解决方案1:
pRecordset->QueryInterface(IID_IDispatch, (void **)m_pRS);
换成
pRecordset->QueryInterface(IID_IDispatch, (void **)&m_pRS);
试下
你可以把代码发给我gw_net@163.com
我帮你看一下
数据库操作步骤:
1.创建数据库连接组件Connection COM,
2.使用连接组件打开你要操作的数据库
3.打开成功之后,即可查询你所需的数据集合。如成功返回记录集(Recordset)接口指针
试下这样。
解决方案5:
CoInitialize(NULL);
_ConnectionPtr m_pConn;
_RecordsetPtr m_pRs(m_pConn);
m_pConn.CreateInstance("ADODB.Connection");
m_pConn->CursorLocation = adUseServer;
m_pConn->CommandTimeout = 5;
m_pConn->Open("Driver={SQL Server};DataBase=table;Server=192.168.0.190;uid=sa;pwd=sa;","","",adOpenUnspecified);
m_pRS->GetFieldValue(1,value);
改成
m_pRS->GetFieldValue(TEXT("字段名"), value);
试下。
您可能想查找下面的文章:
- ADO中的Recordset如保存在Stream中并再由Stream还原
- 如何在VC中,将一个ADO记录集Recordset,转换成OleVariant类型
- 如何实现类似ADO里面记录RecordSet
- 关于ADO连接数据库中,Open、Exexucte等函数用法的区别是什么?
- ADO里Open和Close的问题
- ADO连接数据库的时候m_pConnection的Open函数相关问题
- 在ATL中如何可以传递ADO中的RECORDSET的变量?(传递到网页中
- 组件的函数能否返回ADO的RecordSet对象
- ALT引用ADO返回_Recordset出错
- MFC中AdoDataControl获取Recordset的问题