关于C++ MFC编程 _ConnectionPtr指针连接数据库ACCESS的问题

代码如图所示:
_ConnectionPtr m_pConn;
_variant_t RecordsAffected;
if (FAILED(m_pConn.CreateInstance("ADODB.Connection")))
{
AfxMessageBox(_T("Create Instance failed!"));
return;
}
else
{
m_pConn->Open("Provider=Microsoft.Jet.OLEDB.4.0; Data Source=C://Users//liu//Desktop//database1.mdb", "", "", adModeUnknown);
//m_pConn->Open("Provider=Microsoft.ACE.OLEDB.12.0; Data Source=C://Users//liu//Desktop//数据库1.accdb;Persist Security Info=False;", "", "",adModeUnknown);
try
{
CString sql = _T("INSERT INTO user(username,password) VALUES(\"" + UserName + "\",\"" + Password + "\")");
AfxMessageBox(sql); //察看插入语句
m_pConn->Execute((_bstr_t)sql, &RecordsAffected, adCmdText);
}
catch (_com_error &e)
{
AfxMessageBox(_T("喵喵喵"));
m_pConn->Close();
}
m_pConn->Close();
}
return;
}
之前用JET的连接方式那个没什么问题,但是突然间就不能用了,换了ACE的连接方式还是不可以,程序中断后指向这个地方
inline HRESULT Connection15::Close ( ) {
HRESULT _hr = raw_Close();
if (FAILED(_hr)) _com_issue_errorex(_hr, this, __uuidof(this));
return _hr;
}
求大佬解答是什么原因

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
关于C++ MFC编程 _ConnectionPtr指针连接数据库ACCESS的问题
代码如图所示: _ConnectionPtr m_pConn; _variant_t RecordsAffected; if (FAILED(m_pConn.CreateInstance("ADODB.Connection"))) { AfxMessageBox(_T("Create Instance failed!")); return; } else { m_pConn->Open("Provider=Microsoft.Jet.OLEDB.4.0; Data Source=C://Users//liu//Desktop//database1.mdb", "", "", adModeUnknown); //m_pConn->Open("Provider=Microsoft.ACE.OLEDB.12.0; Data Source=C://Users//liu//Desktop//数据库1.accdb;Persist Security Info=False;", "", "",adModeUnknown); try { CString sql = _T("INSERT INTO user(username,password) VALUES(\"" + UserName + "\",\"" + Password + "\")"); AfxMessageBox(sql); //察看插入语句 m_pConn->Execute((_bstr_t)sql, &RecordsAffected, adCmdText); } catch (_com_error &e) { AfxMessageBox(_T("喵喵喵")); m_pConn->Close(); } m_pConn->Close(); } return; } 之前用JET的连接方式那个没什么问题,但是突然间就不能用了,换了ACE的连接方式还是不可以,程序中断后指向这个地方 inline HRESULT Connection15::Close ( ) { HRESULT _hr = raw_Close(); if (FAILED(_hr)) _com_issue_errorex(_hr, this, __uuidof(this)); return _hr; } 求大佬解答是什么原因
ado连接mssql _ConnectionPtr 对象执行CreateInstance()失败
try { HRESULT hr = m_pConnection.CreateInstance(__uuidof(Connection)); if(FAILED(hr)) { initMsg.Format("创建_ConnectionPtr对象失败"); ShowAndWriteAlarmInfo(initMsg); } char buf[200]; memset(buf,0,200); CString adoString = "Provider=SQLOLEDB.1;Persist Security Info=False;User ID=" + m_szUser + ";password= " + m_szPassword + ";Initial Catalog="+m_szDBName+";Data Source=" + m_szIp + "," + m_szPort; memcpy(buf,adoString,adoString.GetLength()); m_pConnection->ConnectionTimeout = 10; m_pConnection->CommandTimeout = 5; m_pConnection->Mode = adModeUnknown; hr = m_pConnection->Open(buf, "", "", adModeUnknown); if (SUCCEEDED(hr)) { Msg.Format("数据库连接成功"); ShowAndWriteAlarmInfo(initMsg); return TRUE; } } catch(_com_error &e) { m_pConnection = NULL; Msg.Format("无法连接数据库"); ShowAndWriteAlarmInfo(initMsg); TRACE("Code = %0x\n", e.Error()); TRACE("Code meaning = %s\n", (char*) e.ErrorMessage()); TRACE("Source = %s\n", (char*) e.Source()); TRACE("Description = %s\n", (char*) e.Description()); return FALSE; } ``` ``` 打印错误信息: Code = 80004003 Code meaning = 无效指针 Source = (null) Description = (null) 而且有时候可以创建连接成功,有时候不行
求助,关于MFC中ado数据库连接的问题
本人ado编程连接access数据库,却一直连接不上,上连接部分代码。在m_pConnection->Open执行后,返回的hr值为E_FAIL,而且不报错不知如何调试。各位求指教。 _ConnectionPtr m_pConnection; _CommandPtr m_pCommand; _RecordsetPtr m_pRecordset; _bstr_t szConnect = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=D:\\RFIDdata\\goods.mdb"; try { hr = m_pConnection.CreateInstance(__uuidof(Connection)); if (SUCCEEDED(hr)) { m_pConnection->put_CommandTimeout(long(0)); hr =m_pConnection->Open(szConnect,_T(""),_T(""),adModeUnknown); hr = m_pCommand.CreateInstance(__uuidof(Command)); m_pCommand->put_CommandTimeout(long(0)); m_pCommand->put_ActiveConnection(_variant_t(m_pConnection)); }
MFC access数据库连接问题
请求帮助 使用吕鑫老师封装的access连接类,程序会报错,帮忙看一下问题在哪? 已经设置ODBC。 ![图片说明](https://img-ask.csdn.net/upload/201907/30/1564489580_830431.png) ![图片说明](https://img-ask.csdn.net/upload/201907/30/1564489755_910551.png) 封装类文件提示一个错误,但可以成功编译。 ![图片说明](https://img-ask.csdn.net/upload/201907/30/1564489952_201445.png) 程序运行时,报错 ![图片说明](https://img-ask.csdn.net/upload/201907/30/1564490025_418450.png) 下面是吕鑫老师封装类代码 _#_pragma once _#_pragma warning (disable:4146) _#_import "C:\Program Files\Common Files\system\ado\msado15.dll" no_namespace rename("EOF","adoEOF")rename("BOF","adoBOF") class CAdoLx { _RecordsetPtr m_pRst; _ConnectionPtr m_pConn; CString m_szLastError; public: void Release() { m_pConn->Release(); } BOOL GetFieldType(long nIndex, int &nType); enum EType { DBT_ACCESS, DBT_SQL, DBT_ORACLE }; BOOL Connect(EType eType, LPCTSTR szDatabase, LPCTSTR szPass = NULL, LPCTSTR szUser = NULL, LPCTSTR szHost = NULL); int ExecSQL(LPCTSTR szSQL); //int ExecProc(LPCTSTR szSQL); BOOL Select(LPCTSTR szSQL); BOOL IsEOF(); BOOL MoveNext(); BOOL MovePrev(); BOOL MoveFirst(); BOOL MoveLast(); BOOL GetFieldValue(LPCTSTR szField, COleDateTime &tValue); //BOOL GetFieldValue(LPCTSTR szField, double &fValue); BOOL GetFieldValue(LPCTSTR szField, CString &sValue); BOOL GetFieldValue(LPCTSTR szField, int &iValue); //int GetFieldMoney(LPCTSTR szField, double &fValue); BOOL GetFieldByIndex(long nIndex, COleDateTime &tValue); BOOL GetFieldByIndex(long nIndex, double &fValue); BOOL GetFieldByIndex(long nIndex, CString &sValue); BOOL GetFieldByIndex(long nIndex, int &iValue); BOOL GetFieldByIndex(long nIndex, long &lValue); BOOL GetFieldByIndex(long nIndex, DWORD &dwValue); BOOL GetFieldByIndex(long nIndex, UINT &iValue); BOOL GetFieldByIndex(long nIndex, char &cValue); BOOL GetFieldByIndex(long nIndex, short &nValue); BOOL GetFieldByIndex(long nIndex, BYTE &cbValue); BOOL GetFieldByIndex(long nIndex, WORD &wValue); BOOL GetFieldByIndex(long nIndex, TCHAR sValue[], int nSize); int GetFieldCount(); BOOL GetFieldName(long nIndex, CString &szName); int GetRecordCount(); CString GetLastError() { CString str = m_szLastError; m_szLastError.Empty(); return str; } class CProc { /* enum ParameterDirectionEnum { adParamUnknown = 0, adParamInput = 1, adParamOutput = 2, adParamInputOutput = 3, adParamReturnValue = 4 }; */ CString m_szLastError; _CommandPtr m_pCmd; //_ConnectionPtr & m_pConn; public: LPCTSTR GetLastError() const { return m_szLastError; } int Exec(); BOOL Create(_ConnectionPtr &pConn, LPCTSTR szProc); BOOL AddParam(LPCTSTR szVName, long lParam, ParameterDirectionEnum eDir = adParamInput); BOOL AddParam(LPCTSTR szVName, LPCTSTR szParam, ParameterDirectionEnum eDir = adParamInput); BOOL GetValue(LPCTSTR szVName, long &lParam); BOOL GetValue(LPCTSTR szVName, CString &lParam); void Release() { delete this; } CProc() { } }; CProc* CreateProc(LPCTSTR szProc); int ExecProc(CProc* pProc); CAdoLx(); virtual ~CAdoLx(); }; #include "stdafx.h" #include "AdoLx.h" ////////////////////////////////////////////////////////////////////// // Construction/Destruction ////////////////////////////////////////////////////////////////////// CAdoLx::CAdoLx() { ::OleInitialize(NULL); } CAdoLx::~CAdoLx() { } BOOL CAdoLx::Connect(EType eType, LPCTSTR szDatabase, LPCTSTR szPass, LPCTSTR szUser, LPCTSTR szHost) { CString str; switch (eType) { case DBT_ACCESS: { str.Format(TEXT("Provider=MSDASQL.1;Persist Security Info=False;Data Source=MS Access Database;Initial Catalog=%s;Password=%s"), szDatabase, szPass); } break; case DBT_SQL: { str = TEXT("Driver=SQL Server;Server="); str += szHost; str += TEXT(";Database="); str += szDatabase; str += TEXT(";UID="); str += szUser; str += TEXT(";PWD="); str += szPass; } break; case DBT_ORACLE: str = TEXT("Provider=OraOLEDB.Oracle.1;Persist Security Info=False;User ID="); str += szUser; str += TEXT(";Password="); str += szPass; str += TEXT(";Data Source="); str += szDatabase; break; } try { m_pConn.CreateInstance(__uuidof(Connection)); m_pConn->Open(_bstr_t(str), szUser, szPass, adModeUnknown);///连接数据库 } catch (_com_error &e) { m_szLastError = (LPCTSTR)e.Description(); // TRACE(m_szLastError+"\n"); return FALSE; } return TRUE; } int CAdoLx::ExecSQL(LPCTSTR szSql) { _variant_t vRet; try { m_pConn->Execute(szSql, &vRet, adCmdText); } catch (_com_error &e) { m_szLastError = (LPCTSTR)e.Description(); return e.Error(); } return (long)vRet; } BOOL CAdoLx::IsEOF() { try { if (m_pRst->GetadoEOF()) return TRUE; } catch (_com_error &e) { m_szLastError = (LPCTSTR)e.Description(); } return FALSE; } BOOL CAdoLx::Select(LPCTSTR szSQL) { try { if (m_pRst) m_pRst->Close(); m_pRst.CreateInstance(__uuidof(Recordset)); // m_pRst ->Open(szSQL,m_pConn.GetInterfacePtr(),adOpenForwardOnly,adLockReadOnly,adCmdText); m_pRst->Open(szSQL, m_pConn.GetInterfacePtr(), adOpenStatic, adLockReadOnly, adCmdText); } catch (_com_error &e) { m_szLastError = (LPCTSTR)e.Description(); return FALSE; } return TRUE; } int CAdoLx::GetFieldCount() { try { return m_pRst->Fields->Count; } catch (_com_error &e) { m_szLastError = (LPCTSTR)e.Description(); return -1; } return -1; } BOOL CAdoLx::GetFieldByIndex(long nIndex, TCHAR sValue[], int nSize) { try { _variant_t v = m_pRst->GetCollect(nIndex); if (v.vt == VT_NULL) { *sValue = 0; return TRUE; } CString str = v.bstrVal; LPCTSTR p = str; int i = 0; while (--nSize && (*sValue = *p) != 0) { sValue++; p++; } if (!nSize) *sValue = 0; } catch (_com_error &e) { m_szLastError = (LPCTSTR)e.Description(); return FALSE; } return TRUE; } BOOL CAdoLx::GetFieldName(long nIndex, CString &szName) { try { szName = (LPCTSTR)m_pRst->Fields->Item[nIndex]->Name; } catch (_com_error &e) { m_szLastError = (LPCTSTR)e.Description(); return FALSE; } return TRUE; } BOOL CAdoLx::GetFieldValue(LPCTSTR szField, int &iValue) { try { iValue = (long)m_pRst->GetCollect(szField); } catch (_com_error &e) { m_szLastError = (LPCTSTR)e.Description(); return FALSE; } return TRUE; } BOOL CAdoLx::GetFieldByIndex(long nIndex, int &iValue) { try { _variant_t v = m_pRst->GetCollect(nIndex); iValue = (long)v; } catch (_com_error &e) { m_szLastError = (LPCTSTR)e.Description(); return FALSE; } return TRUE; } BOOL CAdoLx::GetFieldByIndex(long nIndex, CString &szValue) { try { _variant_t v = m_pRst->GetCollect(nIndex); if (v.vt == VT_NULL) szValue.Empty(); else szValue = v.bstrVal; } catch (_com_error &e) { m_szLastError = (LPCTSTR)e.Description(); return FALSE; } return TRUE; } BOOL CAdoLx::GetFieldByIndex(long nIndex, COleDateTime &tValue) { try { _variant_t v = m_pRst->GetCollect(nIndex); if (v.vt == VT_NULL) tValue = 0.0; else tValue = v; return TRUE; } catch (_com_error &e) { m_szLastError = (LPCTSTR)e.Description(); return FALSE; } } BOOL CAdoLx::GetFieldByIndex(long nIndex, double &fValue) { try { _variant_t v = m_pRst->GetCollect(nIndex); if (v.vt == VT_NULL) fValue = 0.0; else fValue = v; return TRUE; } catch (_com_error &e) { m_szLastError = (LPCTSTR)e.Description(); return FALSE; } } BOOL CAdoLx::GetFieldByIndex(long nIndex, long &lValue) { try { _variant_t v = m_pRst->GetCollect(nIndex); if (v.vt == VT_NULL) lValue = 0; else lValue = v; return TRUE; } catch (_com_error &e) { m_szLastError = (LPCTSTR)e.Description(); return FALSE; } } /* LONG lVal; BYTE bVal; SHORT iVal; FLOAT fltVal; DOUBLE dblVal; */ BOOL CAdoLx::GetFieldByIndex(long nIndex, DWORD &dwValue) { try { _variant_t v = m_pRst->GetCollect(nIndex); if (v.vt == VT_NULL) dwValue = 0; else dwValue = v.lVal; return TRUE; } catch (_com_error &e) { m_szLastError = (LPCTSTR)e.Description(); return FALSE; } } BOOL CAdoLx::GetFieldByIndex(long nIndex, UINT &iValue) { try { _variant_t v = m_pRst->GetCollect(nIndex); if (v.vt == VT_NULL) iValue = 0; else iValue = v.lVal; return TRUE; } catch (_com_error &e) { m_szLastError = (LPCTSTR)e.Description(); return FALSE; } } BOOL CAdoLx::GetFieldByIndex(long nIndex, char &cValue) { try { _variant_t v = m_pRst->GetCollect(nIndex); if (v.vt == VT_NULL) cValue = 0; else cValue = v.bVal; return TRUE; } catch (_com_error &e) { m_szLastError = (LPCTSTR)e.Description(); return FALSE; } } BOOL CAdoLx::GetFieldByIndex(long nIndex, short &nValue) { try { _variant_t v = m_pRst->GetCollect(nIndex); if (v.vt == VT_NULL) nValue = 0; else nValue = v; return TRUE; } catch (_com_error &e) { m_szLastError = (LPCTSTR)e.Description(); return FALSE; } } BOOL CAdoLx::GetFieldByIndex(long nIndex, BYTE &cbValue) { try { _variant_t v = m_pRst->GetCollect(nIndex); if (v.vt == VT_NULL) cbValue = 0; else cbValue = v; return TRUE; } catch (_com_error &e) { m_szLastError = (LPCTSTR)e.Description(); return FALSE; } } BOOL CAdoLx::GetFieldByIndex(long nIndex, WORD &wValue) { try { _variant_t v = m_pRst->GetCollect(nIndex); if (v.vt == VT_NULL) wValue = 0; else wValue = v.iVal; return TRUE; } catch (_com_error &e) { m_szLastError = (LPCTSTR)e.Description(); return FALSE; } } BOOL CAdoLx::MoveFirst() { try { return m_pRst->MoveFirst() == S_OK; } catch (_com_error &e) { m_szLastError = (LPCTSTR)e.Description(); return FALSE; } } BOOL CAdoLx::MoveLast() { try { return m_pRst->MoveLast() == S_OK; } catch (_com_error &e) { m_szLastError = (LPCTSTR)e.Description(); return FALSE; } } BOOL CAdoLx::MoveNext() { try { return m_pRst->MoveNext() == S_OK; } catch (_com_error &e) { m_szLastError = (LPCTSTR)e.Description(); return FALSE; } } BOOL CAdoLx::MovePrev() { try { return m_pRst->MovePrevious() == S_OK; } catch (_com_error &e) { m_szLastError = (LPCTSTR)e.Description(); return FALSE; } } BOOL CAdoLx::GetFieldType(long nIndex, int &nType) { try { nType = m_pRst->Fields->Item[nIndex]->Type; } catch (_com_error &e) { m_szLastError = (LPCTSTR)e.Description(); return FALSE; } return TRUE; } BOOL CAdoLx::GetFieldValue(LPCTSTR szField, CString &sValue) { try { sValue = m_pRst->GetCollect(szField).bstrVal; return TRUE; } catch (_com_error &e) { m_szLastError = (LPCTSTR)e.Description(); return FALSE; } } BOOL CAdoLx::GetFieldValue(LPCTSTR szField, COleDateTime &tValue) { try { tValue = (DATE)m_pRst->GetCollect(szField); return TRUE; } catch (_com_error &e) { m_szLastError = (LPCTSTR)e.Description(); return FALSE; } } int CAdoLx::GetRecordCount() { try { return m_pRst->GetRecordCount(); } catch (_com_error &e) { m_szLastError = (LPCTSTR)e.Description(); return FALSE; } } BOOL CAdoLx::CProc::Create(_ConnectionPtr &pConn, LPCTSTR szProc) { try { m_pCmd.CreateInstance(__uuidof(Command)); m_pCmd->ActiveConnection = pConn; m_pCmd->CommandType = adCmdStoredProc; m_pCmd->CommandText = _bstr_t(szProc); } catch (_com_error &e) { m_szLastError = (LPCTSTR)e.Description(); return FALSE; } return TRUE; } CAdoLx::CProc* CAdoLx::CreateProc(LPCTSTR szProc) { if (m_pConn == NULL)return FALSE; CProc* pProc = new CProc; if (pProc->Create(m_pConn, szProc)) return pProc; delete pProc; return NULL; } BOOL CAdoLx::CProc::AddParam(LPCTSTR szVName, long lParam, ParameterDirectionEnum eDir) { if (m_pCmd == NULL) return FALSE; try { _ParameterPtr pParam = m_pCmd->CreateParameter(szVName, adInteger, eDir, sizeof(long), lParam); m_pCmd->Parameters->Append(pParam); } catch (_com_error &e) { m_szLastError = (LPCTSTR)e.Description(); return FALSE; } return TRUE; } BOOL CAdoLx::CProc::AddParam(LPCTSTR szVName, LPCTSTR szParam, ParameterDirectionEnum eDir) { if (m_pCmd == NULL) return FALSE; try { _ParameterPtr pParam = m_pCmd->CreateParameter(_bstr_t(szVName), adVarChar, eDir, lstrlen(szParam) + 2, szParam); m_pCmd->Parameters->Append(pParam); } catch (_com_error &e) { m_szLastError = (LPCTSTR)e.Description(); return FALSE; } return TRUE; } int CAdoLx::CProc::Exec() { try { m_pCmd->Execute(NULL, NULL, adCmdStoredProc); } catch (_com_error& e) { m_szLastError = (LPCTSTR)e.Description(); return e.Error(); } return 0; } BOOL CAdoLx::CProc::GetValue(LPCTSTR szVName, long &lParam) { try { _variant_t var = m_pCmd->Parameters->GetItem(_bstr_t(szVName))->GetValue(); lParam = var; } catch (_com_error &e) { m_szLastError = (LPCTSTR)e.Description(); return FALSE; } return TRUE; } BOOL CAdoLx::CProc::GetValue(LPCTSTR szVName, CString &szParam) { try { //_bstr_t bstr = _bstr_t(m_pCmd->Parameters->GetItem(_bstr_t(szVName))->GetValue()); _bstr_t bstr = m_pCmd->Parameters->GetItem(_bstr_t(szVName))->GetValue(); szParam = (LPCTSTR)bstr; } catch (_com_error &e) { m_szLastError = (LPCTSTR)e.Description(); return FALSE; } return TRUE; } int CAdoLx::ExecProc(CProc* pProc) { /* try { if(FAILED(m_pCmd.CreateInstance(__uuidof(Command)))) { return -1; } m_pCmd->ActiveConnection = m_pConn; m_pCmd->CommandType = adCmdStoredProc; m_pCmd->CommandText = L"P_LOGIN"; _ParameterPtr pParam = m_pCmd->CreateParameter(_bstr_t("v_empno"), adInteger, adParamInput ,4,7839L); m_pCmd ->Parameters ->Append(pParam); pParam = m_pCmd->CreateParameter(_bstr_t("v_pass"), adVarChar, adParamInput ,20, "123456"); m_pCmd ->Parameters ->Append(pParam); pParam = m_pCmd->CreateParameter(_bstr_t("v_return"), adInteger, adParamReturnValue, 0); m_pCmd ->Parameters ->Append(pParam); m_pCmd->Execute(NULL, NULL, adCmdStoredProc); long nRet = m_pCmd->Parameters->GetItem("v_return")->GetValue(); } catch(_com_error &e) { m_szLastError =(LPCTSTR) e.Description(); return e.Error(); }*/ return 0; }
C++连接数据库 ADOBE未定义标识符
#pragma warning(default:4146) #import "C:\\Program Files\\Common Files\\System\\ado\\msado15.dll" no_namespace rename ("EOF","adoEOF") #pragma warning(default:4146) using namespace ADODB; _ConnectionPtr m_pConnection; _RecordsetPtr m_pRecordset; _CommandPtr m_pCommand; m_pConnection.CreateInstance(ADODB.Connection); m_pRecordset.CreateInstance(ADODB.Recordset); C++连接数据库总是报错
我用mfc通过ado链接数据库,msado导入进去了,也初始化了。定义链接指针出错了
stdafx.h加入 #import "c:\\Program Files\\Common Files\\System\\ADO\\msado15.dll" rename_namespace("ADOCG") rename("EOF","adoEOF") //rename("BOF","adoBOF") no_namespace 然后定义三个指针 _ConnectionPtr pConnection; _CommandPtr pCmd; _RecordsetPtr pRecord; 编译通不过![图片说明](https://img-ask.csdn.net/upload/201804/03/1522717200_530286.jpg)
_ConnectionPtr pConn 怎么定一成全局的变量
要用变量在不同地方做一些判断,定义成全局的,网上搜到些,可方法不对还是其他情况,编译报错、编译不过去;"class _com_ptr_t<class _com_IIID<struct _Command,&struct __s_GUID _GUID_b08400bd_f9d1_4d02_b856_71d5dba123e9> > pCmd" (?pCmd@@3V?$_com_ptr_t@V?$_com_IIID@U_Command@@$1?_GUID_b08400bd_f9d1_4d02_b856_71d5dba123e9@@3U__s_GU ID@@A@@@@A) already defined in amazing.obj。
ADO连接中第二步是怎么创建指针的呀
_ConnectionPtr m_pConnection; 添加变量的时候,m_pConnection不是只能定义为int、float一类的么?是怎么定义为_ConnectionPtr的?
C++连接SqlServer数据库执行sql语句时出现“对象关闭时,不允许操作。”的错误!
![图片说明](https://img-ask.csdn.net/upload/201708/04/1501838965_981304.jpg) ```cpp CoInitialize(NULL); //初始化指针 _ConnectionPtr sqlsq=NULL; HRESULT hr=sqlsq.CreateInstance(_uuidof(Connection)); if (FAILED(hr)) { cout<<"_ConnectionPtr对象指针实例化失败!!"<<endl; return 0; } else { try{ _bstr_t strConnection="Driver={sql server};server=127.0.0.1,1433;uid=sa;pwd=123456;database=test;";//初始化链接参数 sqlsq->Open(strConnection,"","",adModeUnknown);//执行连接 } //发生连接错误 catch(_com_error &e) { cout<<e.Description()<<endl; } _RecordsetPtr m_pRecordset; _ConnectionPtr m_pConnection; if (FAILED(m_pRecordset.CreateInstance(_uuidof(Recordset)))) { cout<<"记录集对象指针实例化失败!"<<endl; return 0; } try{ m_pRecordset->Open(_variant_t("TEXT_Table"),_variant_t((IDispatch*)sqlsq),adOpenKeyset,adLockOptimistic,adCmdTable); m_pConnection.CreateInstance(_uuidof(Connection)); //初始化Connertion指针 m_pRecordset.CreateInstance(_uuidof(Recordset)); //初始化Recordset指针 CString strsql="select * from TEXT_Table"; //在这里出的错 m_pRecordset=m_pConnection->Execute(_bstr_t(strsql),NULL,adCmdText); while (!m_pRecordset->adoEOF) { CString temp=(TCHAR*)(_bstr_t)m_pRecordset->GetFields()->GetItem("name")->Value; cout<<temp<<endl; m_pRecordset->MoveNext(); } } catch(_com_error &e) { cout<<e.Description()<<endl; } } ```
vs2010 MFC vc++如何保存和显示数据库中的JPG图片代码?
从本地磁盘中读取一张JPG格式的图片到vs2010 MFC界面上,把此图片保存到sql server2008数据库中,并可以从数据库中读取图片在界面上显示出来. 数据库连接是 UpdateData(TRUE); CoInitialize(NULL); _ConnectionPtr pConn(__uuidof(Connection)); _RecordsetPtr pRst(__uuidof(Recordset)); pConn->ConnectionString=(_T("Provider=SQLOLEDB.1;User ID=sa;Password=123456;Persist Security Info=True;Data Source=localhost;Initial Catalog=test")); pConn->Open(_T(""),_T(""),_T(""),adConnectUnspecified); pRst=pConn->Execute(_T("select * from information"),NULL,adCmdText);
MFC ADOC访问数据库用公共类报空指针异常,而不用公共类正常
先建立了个公共类用于数据库连接查询如下 ADOConn头文件 #pragma once //导入AOC动态链接库 #import "C:\Program Files\Common Files\System\ado\msado15.dll" no_namespace\ rename("EOF","adoEOF")rename("BOF","adoBOF") class ADOConn { public: ADOConn(void); virtual~ADOConn(void); _ConnectionPtr m_pConnection; //链接对象指针 _RecordsetPtr m_pRecordset; //记录集对象指针 _CommandPtr m_pCommand; //记录 void OnInitADOConn(void); //连接数据库 void Exitconnect(void); //关闭记录集并断开数据库连接 _RecordsetPtr& GetRecordSet(_bstr_t bstrSQL); //执行SQL查询并返回记录集指针 BOOL ExecuteSQL(_bstr_t bstrSQL); //执行SQL语句 }; ADOConn源文件 #include "StdAfx.h" #include "ADOConn.h" #include "SM2.h" #include <comdef.h> ADOConn::ADOConn(void) { } ADOConn::~ADOConn(void) { } void ADOConn::OnInitADOConn(void) { try { m_pConnection.CreateInstance("ADODB.Connection"); //创建连接对象 // _bstr_t strConnect="Provider=MSDASQL;DSN=Supermarket;UID=sa;PWD=123456;"; _bstr_t strConnect ="Provider = SQLOLEDB; Data Source =localhost; Initial Catlog =Supermarket;\ User ID =sa; Password =123456;"; m_pConnection->Open(strConnect,"","",adModeUnknown); //打开数据库 AfxMessageBox(_T("连接成功")); } catch(_com_error e) { AfxMessageBox(e.Description()); //错误消息 } } _RecordsetPtr& ADOConn::GetRecordSet(_bstr_t bstrSQL) { //TODO: insert return statement here try { if(m_pConnection == NULL) //判断数据库是否连接,如果不连接 OnInitADOConn(); m_pRecordset.CreateInstance(__uuidof(Recordset)); //创建记录集对象实例 m_pRecordset->Open(bstrSQL,m_pConnection.GetInterfacePtr(), adOpenDynamic,adLockOptimistic,adCmdText); //执行SQL到记录集 } catch(_com_error e) { e.Description(); } return m_pRecordset;//返回记录集指针 } BOOL ADOConn::ExecuteSQL(_bstr_t bstrSQL) { try { if(m_pConnection == NULL) //判断数据库是否连接,如果不连接 OnInitADOConn(); m_pConnection->Execute(bstrSQL, NULL, adCmdText); //执行SQL语句 return true; //返回真 } catch( _com_error e) { e.Description(); return false; //返回假 } } void ADOConn::Exitconnect(void) { if(m_pRecordset != NULL) //判断记录集是否打开 m_pRecordset->Close(); //断开记录集 m_pConnection->Close(); //断开数据库 } 然后在查询的时候就会报空指针异常是什么情况 ADOConn m_AdoConnSP; //ADOConn对象 m_AdoConnSP.OnInitADOConn(); //连接数据库 CString sqlSP = _T("select * from Supermarket.dbo.tb_SP"); int i = 0; m_AdoConnSP.m_pRecordset = m_AdoConnSP.GetRecordSet((_bstr_t) sqlSP); //执行SQL语句 while( !m_AdoConnSP.m_pRecordset->adoBOF) { m_Grid.InsertItem(i,_T("")); //向列表中添加行 m_Grid.SetItemText(i, 0, (LPCTSTR)(_bstr_t)m_AdoConnSP.m_pRecordset->GetCollect("SPID")); m_Grid.SetItemText(i, 1, (LPCTSTR)(_bstr_t)m_AdoConnSP.m_pRecordset->GetCollect("SPName")); m_Grid.SetItemText(i, 2, (LPCTSTR)(_bstr_t)m_AdoConnSP.m_pRecordset->GetCollect("SPClass")); m_Grid.SetItemText(i, 3, (LPCTSTR)(_bstr_t)m_AdoConnSP.m_pRecordset->GetCollect("SPUnit")); m_Grid.SetItemText(i, 4, (LPCTSTR)(_bstr_t)m_AdoConnSP.m_pRecordset->GetCollect("SPBarCode")); m_Grid.SetItemText(i, 5, (LPCTSTR)(_bstr_t)m_AdoConnSP.m_pRecordset->GetCollect("PrimeCost")); m_Grid.SetItemText(i, 6, (LPCTSTR)(_bstr_t)m_AdoConnSP.m_pRecordset->GetCollect("SellPrice")); m_Grid.SetItemText(i, 7, (LPCTSTR)(_bstr_t)m_AdoConnSP.m_pRecordset->GetCollect("SPProfit")); m_AdoConnSP.m_pRecordset->MoveNext(); i++; } m_AdoConnSP.Exitconnect(); 然而如果不用公共类的方法就不会报错 try { m_pConnection.CreateInstance("ADODB.Connection"); //创建连接对象 _bstr_t strConnect ="Provider = SQLOLEDB; Data Source =localhost; Initial Catlog =Supermarket;\ User ID =sa; Password =123456;"; m_pConnection->Open(strConnect,"","",adModeUnknown); //打开数据库 AfxMessageBox(_T("连接成功")); } catch(_com_error e) { AfxMessageBox(e.Description()); //错误消息 } //建立查询 CString sql = _T("select * from Supermarket.dbo.tb_SP"); m_pRecordset.CreateInstance(_uuidof(Recordset)); m_pRecordset->Open((_bstr_t)sql,m_pConnection.GetInterfacePtr(), adOpenDynamic,adLockOptimistic,adCmdText); //添加到列表框 int i = 0; while( !m_pRecordset->adoEOF) { m_ListSP.InsertItem(0,_T("")); m_ListSP.SetItemText(i, 0, (LPCTSTR)(_bstr_t)m_pRecordset->GetCollect("SPID")); m_ListSP.SetItemText(i, 1, (LPCTSTR)(_bstr_t)m_pRecordset->GetCollect("SPName")); m_ListSP.SetItemText(i, 2, (LPCTSTR)(_bstr_t)m_pRecordset->GetCollect("SPClass")); m_ListSP.SetItemText(i, 3, (LPCTSTR)(_bstr_t)m_pRecordset->GetCollect("SPUnit")); m_ListSP.SetItemText(i, 4, (LPCTSTR)(_bstr_t)m_pRecordset->GetCollect("SPBarCode")); m_ListSP.SetItemText(i, 5, (LPCTSTR)(_bstr_t)m_pRecordset->GetCollect("PrimeCost")); m_ListSP.SetItemText(i, 6, (LPCTSTR)(_bstr_t)m_pRecordset->GetCollect("SellPrice")); m_ListSP.SetItemText(i, 7, (LPCTSTR)(_bstr_t)m_pRecordset->GetCollect("SPProfit")); m_pRecordset->MoveNext(); } m_pRecordset->Close();
c++ADO连接sqlserver怎么设置超时
如果超过设定的时间还没有连接成功就断开连接,用_connectionptr能实现吗
VC6.0 MFC两个对话框之间的数据通信
做的一个成绩查询系统,想实现先登录,再查询 我在第一个对话框中输入学号,密码,登陆成功 UpdateData(true); _variant_t var; CString strName = ""; _ConnectionPtr m_pConnection; _CommandPtr m_pCommand; _RecordsetPtr m_pRecordset; CString SQL; char*STRSQL; SQL="SELECT * FROM studentinfo WHERE num='"+m_num+"' and pwd='"+m_pwd+"'"; STRSQL=SQL.GetBuffer(SQL.GetLength()); ::CoInitialize(NULL); m_pConnection.CreateInstance(__uuidof(Connection)); try { m_pConnection->Open("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=student.mdb","","",adModeUnknown); m_pRecordset.CreateInstance(__uuidof(Recordset)); m_pRecordset->Open(STRSQL, m_pConnection.GetInterfacePtr(), // 获取库接库的IDispatch指针 adOpenDynamic, adLockOptimistic, adCmdText); 连上了数据库,怎样在第三个对话框里来显示刚刚登陆的时候连上的数据库里的信息? m_List.DeleteAllItems(); UpdateData(TRUE); _variant_t var; CString strName = ""; _ConnectionPtr m_pConnection; _CommandPtr m_pCommand; _RecordsetPtr m_pRecordset; CString SQL; char*STRSQL; ** */*CYyyDlg rt; m_NUM=rt.m_num; UpdateData(false);*/* ** 我本来想这样来实现,把m_num的值赋给m_NUM,但是没用 SQL="SELECT * FROM studentinfo WHERE num='"+m_NUM+"'"; STRSQL=SQL.GetBuffer(SQL.GetLength()); ::CoInitialize(NULL); m_pConnection.CreateInstance(__uuidof(Connection)); try { m_pConnection->Open("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=student.mdb","","",adModeUnknown);
ado与数据库连接时成功了,但用参数化查询时却报错unkown error 0x800A0E7D
数据库用的是server 2005,但在下载时遇到了问题,,后来求助网上,完成后,程序名却叫microsoft sql server studio express,不晓得是不是数据库的问题。 ***希望大神指点!*** 以下是我的代码: 我在CADOcon定义了_connectionptr指针,所以connection这一部分应该是没问题的。 void AddUser::OnOK() { // TODO: Add extra validation here try { UpdateData(); if(m_username.GetLength()==0&&m_pws.GetLength()==0&&m_pwsr.GetLength()==0) { return; } CADOcon adocon; adocon.Getinado(); //添加执行命令 _CommandPtr pCommand; pCommand = NULL; pCommand.CreateInstance(__uuidof(Command)); _ConnectionPtr pConnection; pCommand->ActiveConnection=pConnection; pCommand->CommandText=("insert into 用户([用户_id],密码) values(?,?)"); pCommand->CommandTimeout=5; _variant_t vRecordsAffected; _ParameterPtr pParam1 =pCommand->CreateParameter(_bstr_t("用户_id"),adBSTR,adParamInput, m_username.GetLength(),_variant_t(m_username)); _ParameterPtr pParam2 =pCommand->CreateParameter(_bstr_t("密码"),adBSTR,adParamInput, m_username.GetLength(),_variant_t(m_pws)); pCommand->Parameters->Append(pParam1); pCommand->Parameters->Append(pParam2); pCommand->Execute(&vRecordsAffected,NULL,adCmdText); if(vRecordsAffected.intVal==1) { AfxMessageBox("添加成功"); } if(pConnection->State) { pConnection->Close(); } } catch(_com_error& e) { CString strMsg; strMsg.Format(_T("错误描述:%s\n错误消息%s"), (LPCTSTR)e.Description(), (LPCTSTR)e.ErrorMessage()); AfxMessageBox(strMsg); }
Visualo stdio 2012 连接localDB 出错
用Visual Studio 2012 连接localdb 报错,多步OLEDB操作产生错误。如果可能,请检查每个OLEDB状态值,没有工作被完成。 CoInitialize(NULL); _ConnectionPtr m_pConnection; _CommandPtr m_pCommand; _RecordPtr m_pRecord; _ParameterPtr m_pParameter; HRESULT hr=m_pConnection.CreateInstance(__uuidof(Connection)); if(FAILED(hr)) { cout<<"_ConnectionPtr对象指针实例化失败!!!"<<endl; return false; } try{ CString strConnect=_T("Data Source=(LocalDB)\\v11.0;Initial Catalog=TestPeople;AttachDbFilename=C:\\Users\\A2040271\\TestPeople.mdf;Integrated Security=True;"); m_pConnection->Open((_bstr_t)strConnect,(_bstr_t)"",(_bstr_t)"",(long)adModeUnknown); } catch(_com_error &e){ cout<<e.Description()<<endl; }
MFC ADO链接数据库问题
listBookInfo("select * from Table_Book"); 这一句显示错误:错误 C2664 “void CTestDlg::listBookInfo(CString)”: 无法将参数 1 从“const char [25]”转换为“CString” Test f:\summerholidayhomework\test\test\testdlg.cpp 119 不存在从 "const char [25]" 转换到 "ATL::CStringT<wchar_t, StrTraitMFC_DLL<wchar_t, ATL::ChTraitsCRT<wchar_t>>>" 的适当构造函数 Test f:\SummerHolidayhomework\Test\Test\TestDlg.cpp 119 //Ado数据库连接函数 void CTestDlg::listBookInfo(CString strSQL) { m_listBookInfo.DeleteAllItems(); // 首先清空列表视图中的所有数据 _ConnectionPtr m_pConnection; // 创建连接对象指针 m_pConnection.CreateInstance(_uuidof(Connection));// 创建连接对象实例 //在ADO操作中建议语句中要常用try...catch()来捕获错误信息 try { //打开本地SQL数据库Book.mdf m_pConnection->Open("Data Source=(LocalDB)\MSSQLLocalDB;AttachDbFilename=F:\SummerHolidayhomework\Test\Book.mdf;Integrated Security=Ture;Connect Timeout=30", "", "", adModeUnknown); } catch (_com_error e) { e.Error(); MessageBox(e.ErrorMessage()); MessageBox(e.Description()); return; } _RecordsetPtr m_pRecordset; // 创建记录集对象指针 m_pRecordset.CreateInstance(__uuidof(Recordset));//创建记录集指针对象实例 try { m_pRecordset->Open( _variant_t(strSQL), // 打开记录集 m_pConnection.GetInterfacePtr(), // 获取库接库的IDispatch指针 adOpenDynamic, // 动态光标 adLockOptimistic, // 乐观锁定方式 adCmdText // CommandText是文本命令 ); } catch (_com_error *e) { AfxMessageBox(e->ErrorMessage()); } _variant_t var; CString strTmp; while (!m_pRecordset->adoEOF) { var = m_pRecordset->GetCollect("书号"); // 获取书号字段的值 strTmp = (LPCSTR)_bstr_t(var); m_listBookInfo.InsertItem(0, strTmp); var = m_pRecordset->GetCollect("书名"); // 获取书名字段的值 strTmp = (LPCSTR)_bstr_t(var); m_listBookInfo.SetItemText(1, 1, strTmp); var = m_pRecordset->GetCollect("类别"); // 获取类型字段的值 strTmp = (LPCSTR)_bstr_t(var); m_listBookInfo.SetItemText(2, 2, strTmp); var = m_pRecordset->GetCollect("单价"); // 获取单价字段的值 strTmp = (LPCSTR)_bstr_t(var); m_listBookInfo.SetItemText(3, 3, strTmp); //将记录集指针移动到下一条记录 m_pRecordset->MoveNext(); } m_pRecordset->Close(); // 关闭记录集 m_pRecordset.Release(); // 释放记录集对象 m_pRecordset = NULL; if (m_pConnection->State) m_pConnection->Close(); // 关闭与数据库的连接 m_pConnection = NULL; UpdateData(FALSE); }
MFC 运行程序遇到abnormal program termination,可能连接数据库有问题
C++6.0用ADO连接SQL,编译没问题,运行有错误,现在实现登录然后弹出主窗口 ADo代码 // ADO.cpp: implementation of the CADO class. // ////////////////////////////////////////////////////////////////////// #include "stdafx.h" #include "ADO.h" #include <comdef.h> #ifdef _DEBUG #undef THIS_FILE static char THIS_FILE[]=__FILE__; #define new DEBUG_NEW #endif ////////////////////////////////////////////////////////////////////// // Construction/Destruction ////////////////////////////////////////////////////////////////////// int ConCount = 0; CADOConnection g_Connection;//全局数据库连接对象 CADOConnection * GetConnection() { return &g_Connection; } CADOConnection::CADOConnection() { InitADO(); m_Connection.CreateInstance("ADODB.Connection"); } CADOConnection::~CADOConnection() { if (IsOpen()) m_Connection->Close(); m_Connection = NULL; UnInitADO(); } void CADOConnection::InitADO() { if (ConCount++ == 0) CoInitialize(NULL); }; void CADOConnection::UnInitADO() { if (--ConCount == 0) CoUninitialize(); }; BOOL CADOConnection::Open(CString ConStr) { if (IsOpen()) m_Connection->Close(); m_Connection->Open((_bstr_t)ConStr,"","",adModeUnknown); return IsOpen(); } CString CADOConnection::GetSQLConStr(CString IP, CString DBName) { CString Str; Str.Format("Provider=SQLOLEDB.1;Persist Security Info=False;User ID=sa;Initial Catalog=%s;Data Source=%s",DBName,IP); return Str; } _ConnectionPtr CADOConnection::GetConnection() { return m_Connection; } BOOL CADOConnection::IsOpen() { long State; m_Connection->get_State(&State); if (State == adStateOpen) return true; return false; } //////////////////////////////////////// CADODataSet::CADODataSet() { m_DataSet.CreateInstance("ADODB.Recordset"); } CADODataSet::~CADODataSet() { if (IsOpen()) m_DataSet->Close(); m_DataSet = NULL; m_Connection = NULL; } void CADODataSet::SetConnection(CADOConnection *pCon) { m_Connection = pCon; } int CADODataSet::GetRecordCount() { if (IsOpen()) return m_DataSet->GetRecordCount(); else return 0; } BOOL CADODataSet::Open(CString SQLStr) { if (IsOpen()) m_DataSet->Close(); //*/ m_DataSet->Open(_bstr_t(SQLStr), _variant_t((IDispatch*)g_Connection.GetConnection(), true), adOpenKeyset, adLockOptimistic, adCmdText); return IsOpen(); //*/ } BOOL CADODataSet::IsOpen() { long State; m_DataSet->get_State(&State); if (State == adStateOpen) return true; return false; } FieldsPtr CADODataSet::GetFields() { return m_DataSet->GetFields(); } BOOL CADODataSet::Next() { if (m_DataSet->adoEOF) return false; m_DataSet->MoveNext(); return true; } void CADODataSet::AddNew() { m_DataSet->AddNew(); } void CADODataSet::SetFieldValue(CString FieldName, _variant_t Value) { m_DataSet->PutCollect((_bstr_t)FieldName,Value); } void CADODataSet::Save() { m_DataSet->Update(); } void CADODataSet::move(int nIndex) { m_DataSet->MoveFirst(); m_DataSet->Move(nIndex); } int CADODataSet::GetRecordNo() { return m_DataSet->AbsolutePosition; } void CADODataSet::Delete() { m_DataSet->Delete(adAffectCurrent); } BOOL CADODataSet::Open(CString SQLStr, int LockType) { if (IsOpen()) m_DataSet->Close(); //*/ m_DataSet->Open(_bstr_t(SQLStr), _variant_t((IDispatch*)g_Connection.GetConnection(), true), adOpenKeyset,(LockTypeEnum) LockType, adCmdText); return IsOpen(); } **Award.cpp** // LoginDialog.cpp : implementation file // #include "stdafx.h" #include "Award.h" #include "ADO.h" #include "LoginDialog.h" #ifdef _DEBUG #define new DEBUG_NEW #undef THIS_FILE static char THIS_FILE[] = __FILE__; #endif ///////////////////////////////////////////////////////////////////////////// // CLoginDialog dialog CLoginDialog::CLoginDialog(CWnd* pParent /*=NULL*/) : CDialog(CLoginDialog::IDD, pParent) { //{{AFX_DATA_INIT(CLoginDialog) //}}AFX_DATA_INIT } void CLoginDialog::DoDataExchange(CDataExchange* pDX) { CDialog::DoDataExchange(pDX); //{{AFX_DATA_MAP(CLoginDialog) DDX_Control(pDX, IDC_EDIT1, m_password); DDX_Control(pDX, IDC_COMUSERLIST, m_userlist); //}}AFX_DATA_MAP } BEGIN_MESSAGE_MAP(CLoginDialog, CDialog) //{{AFX_MSG_MAP(CLoginDialog) ON_BN_CLICKED(IDOK, OnLogin) //}}AFX_MSG_MAP END_MESSAGE_MAP() ///////////////////////////////////////////////////////////////////////////// // CLoginDialog message handlers void CLoginDialog::OnLogin() { CString sql,user,pass; m_userlist.GetWindowText(user); m_password.GetWindowText(pass); sql.Format("Select * From User Where userName = '%s' and passWord = '%s'", user,pass); m_DataSet.Open(sql); if (m_DataSet.GetRecordCount() == 1) { ::SetUserName(user); this->OnOK(); } else AfxMessageBox("用户名或密码不正确!"); } BOOL CLoginDialog::OnInitDialog() { CDialog::OnInitDialog(); m_DataSet.SetConnection(GetConnection()); m_DataSet.Open("Select * From User"); int count = m_DataSet.GetRecordCount(); for (int i = 0; i< count;i++) { m_userlist.AddString((_bstr_t)m_DataSet.GetFields()->Item[L"UserName"]->Value); m_DataSet.Next(); } m_userlist.SetCurSel(0); return TRUE; // return TRUE unless you set the focus to a control // EXCEPTION: OCX Property Pages should return FALSE }
win32 C++应用程序放到Server08下连接oracle报错
程序是C++的,连接本地Oracle数据库,方法为 CoInitialize(NULL); _ConnectionPtr conn; try{ conn.CreateInstance(__uuidof(Connection)); conn->Open("Provider=OraOLEDB.Oracle.1;Data Source=ORACLE;Persist Security Info=false;Password=123;User ID=123","","",NULL); } catch(_com_error &e){ cout<< e.Description() <<endl; } 原来的程序是server03(32位)系统下VS建的win32控制台应用程序,是正常的,后来系统重装成server08(64位),数据库也重装成了64位的oracle(PL/SQL 可以正常登陆),但C++连接数据库这里就报错了,提示“未找到提供程序,该程序可能未正确安装”,测了一下VS下把程序重新编译成X64就好了,但是我还是想用原来的32位的程序(因为项目还含有一些32位下的链接库),请问这怎么解决啊?
在MFC中用ADO连接excel时找不到数据表
无论是用ADO的OpenSchema( adSchemaTables ),还是用 ADOX 的 _CatalogPtr 找系统表,都找不到数据表,而文件里面又确实有一个表,这是什么原因? 附程序代码: ADODB::_ConnectionPtr m_pConnection; ADODB::_RecordsetPtr m_pRecordset; ::CoInitialize( NULL ); m_pConnection.CreateInstance( __uuidof( ADODB::Connection ) ); m_pRecordset.CreateInstance( __uuidof( ADODB::Recordset ) ); CString csConnect; csConnect.Format("Provider=Microsoft.ACE.OLEDB.12.0;" "Data Source='txlx.xls'; Extended Properties='Excel 8.0;HDR=YES;IMEX=0'" ); _bstr_t strConnect; strConnect = csConnect; try{ m_pConnection ->Open( strConnect, "", "", ADODB::adConnectUnspecified ); } catch( _com_error &e ) { CString szError; szError.Format( "数据库连接失败!\n%s\n%s", e.ErrorMessage(), (char*)(e.Description()) ); MessageBox( szError ); } _CatalogPtr m_pCatalog = NULL; _TablePtr m_pTable = NULL; m_pCatalog.CreateInstance( __uuidof( Catalog )); try{ m_pCatalog ->PutActiveConnection( _variant_t((IDispatch*)m_pConnection)); } catch( _com_error &e ) { CString szError; szError.Format( "数据目录关联失败!\n%s\n%s", e.ErrorMessage(), (char*)(e.Description()) ); MessageBox( szError ); } _variant_t vIndex = (short)0; try{ m_pTable = m_pCatalog ->Tables ->GetItem( vIndex ); AfxMessageBox( m_pTable ->Name ); } catch( _com_error &e ) { CString szError; szError.Format( "数据表获取失败!\n%s\n%s", e.ErrorMessage(), (char*)(e.Description()) ); MessageBox( szError ); } if( m_pRecordset != NULL && m_pRecordset ->State == ADODB::adStateOpen ) { m_pRecordset ->Close(); } if( m_pConnection != NULL ) { m_pConnection->Close(); } m_pConnection.Release(); m_pRecordset.Release(); ::CoUninitialize(); 错误提示:数据表获取失败! 在对应所需名称或序数的集合中,未找到项目。
ADO连接SQL server无效指针
ADO连接SQL server2008 使用_CommandPtr pCommand的对象时出现无效指针,代码: void CMy123Dlg::OnCommand() { try { _ConnectionPtr pConnection=NULL; pConnection.CreateInstance(_uuidof(Connection)); pConnection->Mode=adModeUnknown; pConnection->ConnectionTimeout=5; pConnection->ConnectionString=_T("Data Source=127.0.0.1;Provider=SQLOLEDB.1;Initial Catalog=自行车"); HRESULT hr= pConnection->Open(_T(""), _T("zxf"),_T("1234"), adModeUnknown); if(FAILED(hr)) { pConnection->Close(); MessageBox("连接失败了"); return ; } //CString ID; //GetDlgItemText(IDC_ID,ID); _CommandPtr pCommand=NULL; pCommand.CreateInstance(_uuidof(pCommand)); pCommand->ActiveConnection=pConnection; pCommand->CommandText=_T("insert into 类型([ID]) values(?)"); pConnection->CommandTimeout=5; _variant_t vRecordsAffected; _ParameterPtr pParam1=pCommand->CreateParameter(_bstr_t("ID"),adBSTR,adParamInput,m_ID.GetLength(),_variant_t(m_ID)); pCommand->Parameters->Append(pParam1); pCommand->Execute(&vRecordsAffected,NULL,adCmdText); if(vRecordsAffected.intVal==1) { MessageBox("添加成功了"); } if(pConnection->State) { pConnection->Close(); pConnection=NULL; } } catch(_com_error &e) { AfxMessageBox(e.ErrorMessage()); } }
相见恨晚的超实用网站
搞学习 知乎:www.zhihu.com 简答题:http://www.jiandati.com/ 网易公开课:https://open.163.com/ted/ 网易云课堂:https://study.163.com/ 中国大学MOOC:www.icourse163.org 网易云课堂:study.163.com 哔哩哔哩弹幕网:www.bilibili.com 我要自学网:www.51zxw
花了20分钟,给女朋友们写了一个web版群聊程序
参考博客 [1]https://www.byteslounge.com/tutorials/java-ee-html5-websocket-example
爬虫福利二 之 妹子图网MM批量下载
爬虫福利一:27报网MM批量下载    点击 看了本文,相信大家对爬虫一定会产生强烈的兴趣,激励自己去学习爬虫,在这里提前祝:大家学有所成! 目标网站:妹子图网 环境:Python3.x 相关第三方模块:requests、beautifulsoup4 Re:各位在测试时只需要将代码里的变量 path 指定为你当前系统要保存的路径,使用 python xxx.py 或IDE运行即可。
字节跳动视频编解码面经
引言 本文主要是记录一下面试字节跳动的经历。 三四月份投了字节跳动的实习(图形图像岗位),然后hr打电话过来问了一下会不会opengl,c++,shador,当时只会一点c++,其他两个都不会,也就直接被拒了。 七月初内推了字节跳动的提前批,因为内推没有具体的岗位,hr又打电话问要不要考虑一下图形图像岗,我说实习投过这个岗位不合适,不会opengl和shador,然后hr就说秋招更看重基础。我当时
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
linux系列之常用运维命令整理笔录
本博客记录工作中需要的linux运维命令,大学时候开始接触linux,会一些基本操作,可是都没有整理起来,加上是做开发,不做运维,有些命令忘记了,所以现在整理成博客,当然vi,文件操作等就不介绍了,慢慢积累一些其它拓展的命令,博客不定时更新 顺便拉下票,我在参加csdn博客之星竞选,欢迎投票支持,每个QQ或者微信每天都可以投5票,扫二维码即可,http://m234140.nofollow.ax.
比特币原理详解
一、什么是比特币 比特币是一种电子货币,是一种基于密码学的货币,在2008年11月1日由中本聪发表比特币白皮书,文中提出了一种去中心化的电子记账系统,我们平时的电子现金是银行来记账,因为银行的背后是国家信用。去中心化电子记账系统是参与者共同记账。比特币可以防止主权危机、信用风险。其好处不多做赘述,这一层面介绍的文章很多,本文主要从更深层的技术原理角度进行介绍。 二、问题引入 假设现有4个人...
Python 基础(一):入门必备知识
目录1 标识符2 关键字3 引号4 编码5 输入输出6 缩进7 多行8 注释9 数据类型10 运算符10.1 常用运算符10.2 运算符优先级 1 标识符 标识符是编程时使用的名字,用于给变量、函数、语句块等命名,Python 中标识符由字母、数字、下划线组成,不能以数字开头,区分大小写。 以下划线开头的标识符有特殊含义,单下划线开头的标识符,如:_xxx ,表示不能直接访问的类属性,需通过类提供
这30个CSS选择器,你必须熟记(上)
关注前端达人,与你共同进步CSS的魅力就是让我们前端工程师像设计师一样进行网页的设计,我们能轻而易举的改变颜色、布局、制作出漂亮的影音效果等等,我们只需要改几行代码,不需...
国产开源API网关项目进入Apache孵化器:APISIX
点击蓝色“程序猿DD”关注我回复“资源”获取独家整理的学习资料!近日,又有一个开源项目加入了这个Java开源界大名鼎鼎的Apache基金会,开始进行孵化器。项目名称:AP...
程序员接私活怎样防止做完了不给钱?
首先跟大家说明一点,我们做 IT 类的外包开发,是非标品开发,所以很有可能在开发过程中会有这样那样的需求修改,而这种需求修改很容易造成扯皮,进而影响到费用支付,甚至出现做完了项目收不到钱的情况。 那么,怎么保证自己的薪酬安全呢? 我们在开工前,一定要做好一些证据方面的准备(也就是“讨薪”的理论依据),这其中最重要的就是需求文档和验收标准。一定要让需求方提供这两个文档资料作为开发的基础。之后开发
网页实现一个简单的音乐播放器(大佬别看。(⊙﹏⊙))
今天闲着无事,就想写点东西。然后听了下歌,就打算写个播放器。 于是乎用h5 audio的加上js简单的播放器完工了。 欢迎 改进 留言。 演示地点跳到演示地点 html代码如下`&lt;!DOCTYPE html&gt; &lt;html&gt; &lt;head&gt; &lt;title&gt;music&lt;/title&gt; &lt;meta charset="utf-8"&gt
Python十大装B语法
Python 是一种代表简单思想的语言,其语法相对简单,很容易上手。不过,如果就此小视 Python 语法的精妙和深邃,那就大错特错了。本文精心筛选了最能展现 Python 语法之精妙的十个知识点,并附上详细的实例代码。如能在实战中融会贯通、灵活使用,必将使代码更为精炼、高效,同时也会极大提升代码B格,使之看上去更老练,读起来更优雅。 1. for - else 什么?不是 if 和 else 才
数据库优化 - SQL优化
前面一篇文章从实例的角度进行数据库优化,通过配置一些参数让数据库性能达到最优。但是一些“不好”的SQL也会导致数据库查询变慢,影响业务流程。本文从SQL角度进行数据库优化,提升SQL运行效率。 判断问题SQL 判断SQL是否有问题时可以通过两个表象进行判断: 系统级别表象 CPU消耗严重 IO等待严重 页面响应时间过长
2019年11月中国大陆编程语言排行榜
2019年11月2日,我统计了某招聘网站,获得有效程序员招聘数据9万条。针对招聘信息,提取编程语言关键字,并统计如下: 编程语言比例 rank pl_ percentage 1 java 33.62% 2 c/c++ 16.42% 3 c_sharp 12.82% 4 javascript 12.31% 5 python 7.93% 6 go 7.25% 7
通俗易懂地给女朋友讲:线程池的内部原理
餐厅的约会 餐盘在灯光的照耀下格外晶莹洁白,女朋友拿起红酒杯轻轻地抿了一小口,对我说:“经常听你说线程池,到底线程池到底是个什么原理?”我楞了一下,心里想女朋友今天是怎么了,怎么突然问出这么专业的问题,但做为一个专业人士在女朋友面前也不能露怯啊,想了一下便说:“我先给你讲讲我前同事老王的故事吧!” 大龄程序员老王 老王是一个已经北漂十多年的程序员,岁数大了,加班加不动了,升迁也无望,于是拿着手里
经典算法(5)杨辉三角
杨辉三角 是经典算法,这篇博客对它的算法思想进行了讲解,并有完整的代码实现。
编写Spring MVC控制器的14个技巧
本期目录 1.使用@Controller构造型 2.实现控制器接口 3.扩展AbstractController类 4.为处理程序方法指定URL映射 5.为处理程序方法指定HTTP请求方法 6.将请求参数映射到处理程序方法 7.返回模型和视图 8.将对象放入模型 9.处理程序方法中的重定向 10.处理表格提交和表格验证 11.处理文件上传 12.在控制器中自动装配业务类 ...
腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹?
昨天,有网友私信我,说去阿里面试,彻底的被打击到了。问了为什么网上大量使用ThreadLocal的源码都会加上private static?他被难住了,因为他从来都没有考虑过这个问题。无独有偶,今天笔者又发现有网友吐槽了一道腾讯的面试题,我们一起来看看。 腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹? 在互联网职场论坛,一名程序员发帖求助到。二面腾讯,其中一个算法题:64匹
面试官:你连RESTful都不知道我怎么敢要你?
面试官:了解RESTful吗? 我:听说过。 面试官:那什么是RESTful? 我:就是用起来很规范,挺好的 面试官:是RESTful挺好的,还是自我感觉挺好的 我:都挺好的。 面试官:… 把门关上。 我:… 要干嘛?先关上再说。 面试官:我说出去把门关上。 我:what ?,夺门而去 文章目录01 前言02 RESTful的来源03 RESTful6大原则1. C-S架构2. 无状态3.统一的接
求小姐姐抠图竟遭白眼?痛定思痛,我决定用 Python 自力更生!
点击蓝色“Python空间”关注我丫加个“星标”,每天一起快乐的学习大家好,我是 Rocky0429,一个刚恰完午饭,正在用刷网页浪费生命的蒟蒻...一堆堆无聊八卦信息的网页内容慢慢使我的双眼模糊,一个哈欠打出了三斤老泪,就在此时我看到了一张图片:是谁!是谁把我女朋友的照片放出来的!awsl!太好看了叭...等等,那个背景上的一堆鬼画符是什么鬼?!真是看不下去!叔叔婶婶能忍,隔壁老王的三姨妈的四表...
为啥国人偏爱Mybatis,而老外喜欢Hibernate/JPA呢?
关于SQL和ORM的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行了一番讨论,感触还是有一些,于是就有了今天这篇文。 声明:本文不会下关于Mybatis和JPA两个持久层框架哪个更好这样的结论。只是摆事实,讲道理,所以,请各位看官勿喷。 一、事件起因 关于Mybatis和JPA孰优孰劣的问题,争论已经很多年了。一直也没有结论,毕竟每个人的喜好和习惯是大不相同的。我也看
SQL-小白最佳入门sql查询一
不要偷偷的查询我的个人资料,即使你再喜欢我,也不要这样,真的不好;
项目中的if else太多了,该怎么重构?
介绍 最近跟着公司的大佬开发了一款IM系统,类似QQ和微信哈,就是聊天软件。我们有一部分业务逻辑是这样的 if (msgType = "文本") { // dosomething } else if(msgType = "图片") { // doshomething } else if(msgType = "视频") { // doshomething } else { // doshom...
致 Python 初学者
欢迎来到“Python进阶”专栏!来到这里的每一位同学,应该大致上学习了很多 Python 的基础知识,正在努力成长的过程中。在此期间,一定遇到了很多的困惑,对未来的学习方向感到迷茫。我非常理解你们所面临的处境。我从2007年开始接触 python 这门编程语言,从2009年开始单一使用 python 应对所有的开发工作,直至今天。回顾自己的学习过程,也曾经遇到过无数的困难,也曾经迷茫过、困惑过。开办这个专栏,正是为了帮助像我当年一样困惑的 Python 初学者走出困境、快速成长。希望我的经验能真正帮到你
“狗屁不通文章生成器”登顶GitHub热榜,分分钟写出万字形式主义大作
一、垃圾文字生成器介绍 最近在浏览GitHub的时候,发现了这样一个骨骼清奇的雷人项目,而且热度还特别高。 项目中文名:狗屁不通文章生成器 项目英文名:BullshitGenerator 根据作者的介绍,他是偶尔需要一些中文文字用于GUI开发时测试文本渲染,因此开发了这个废话生成器。但由于生成的废话实在是太过富于哲理,所以最近已经被小伙伴们给玩坏了。 他的文风可能是这样的: 你发现,...
程序员:我终于知道post和get的区别
是一个老生常谈的话题,然而随着不断的学习,对于以前的认识有很多误区,所以还是需要不断地总结的,学而时习之,不亦说乎
《程序人生》系列-这个程序员只用了20行代码就拿了冠军
你知道的越多,你不知道的越多 点赞再看,养成习惯GitHub上已经开源https://github.com/JavaFamily,有一线大厂面试点脑图,欢迎Star和完善 前言 这一期不算《吊打面试官》系列的,所有没前言我直接开始。 絮叨 本来应该是没有这期的,看过我上期的小伙伴应该是知道的嘛,双十一比较忙嘛,要值班又要去帮忙拍摄年会的视频素材,还得搞个程序员一天的Vlog,还要写BU...
相关热词 如何提升c#开发能力 矩阵乘法c# c#调用谷歌浏览器 c# 去空格去转义符 c#用户登录窗体代码 c# 流 c# linux 可视化 c# mvc 返回图片 c# 像素空间 c# 日期 最后一天
立即提问