[VC++ MFC编程] 关于CDatabase的一个问题
在编程的时候,我在某类中定义了一个CDatabase类和CRecordset类的成员变量,在该类的初始化函数中调用了CDatabase::Open()函数打开了数据库,而...
在编程的时候,我在某类中定义了一个CDatabase类和CRecordset类的成员变量,在该类的初始化函数中调用了CDatabase::Open()函数打开了数据库,而在该类的另一个成员函数调用了CRecordset::Open()进行查询(步骤都是按参考书)可是这里就出现错误,提示“无效的游标状态”,我追踪了错误,发现是CRecordset::IsOpen()(由Open函数调用)函数报错。而如果我把CDatabase::Open()和CRecordset::Open()放在同一函数调用,就不会有错,但是这样每次运行程序都先会弹出选择数据库的对话框,这不是我所希望的结果。现在的问题是把这两个CDatabase::Open()和CRecordset::Open()分别放在不同的函数调用(但在同一个类中实现)难道不行么??怎么解决上面的冲突???
展开
2个回答
展开全部
strFile.Format("C:\\WINDOWS\\system32\\drivers\\filter.sys");
CString strDsn;
strDsn.Format("ODBC;DRIVER={%s};UID=sa;PWD=greenwall91061est;DBQ=%s",strDriver,strFile);
CDatabase m_db
m_db.Open(NULL,false,false,strDsn);
CString strConnect = m_db.GetConnect();
CRecordset rs(&m_db);
strSql1.Format("select * from tempSite WHERE temp_url = '%s'", AllowURL);
rs.Open(CRecordset::forwardOnly,strSql1,CRecordset::appendOnly);
CString strDsn;
strDsn.Format("ODBC;DRIVER={%s};UID=sa;PWD=greenwall91061est;DBQ=%s",strDriver,strFile);
CDatabase m_db
m_db.Open(NULL,false,false,strDsn);
CString strConnect = m_db.GetConnect();
CRecordset rs(&m_db);
strSql1.Format("select * from tempSite WHERE temp_url = '%s'", AllowURL);
rs.Open(CRecordset::forwardOnly,strSql1,CRecordset::appendOnly);
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询