博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
mfc 链接 access 2007 数据库
阅读量:6799 次
发布时间:2019-06-26

本文共 4267 字,大约阅读时间需要 14 分钟。

神马也不说了,直接给出源代码和project

原理这个东西 Google  下。都出来了。自己就说下作为新手 ,

1 应该打印出,链接错误原因

2 应该将数据库放到project以下,特别注意这点

stdafx.h

// stdafx.h : 标准系统包括文件的包括文件,// 或是常常使用但不常更改的// 特定于项目的包括文件#pragma once#ifndef _SECURE_ATL#define _SECURE_ATL 1#endif#ifndef VC_EXTRALEAN#define VC_EXTRALEAN            // 从 Windows 头中排除极少使用的资料#endif#include "targetver.h"#define _ATL_CSTRING_EXPLICIT_CONSTRUCTORS      // 某些 CString 构造函数将是显式的// 关闭 MFC 对某些常见但常常可放心忽略的警告消息的隐藏#define _AFX_ALL_WARNINGS#include 
// MFC 核心组件和标准组件#include
// MFC 扩展#include
// MFC 自己主动化类#ifndef _AFX_NO_OLE_SUPPORT#include
// MFC 对 Internet Explorer 4 公共控件的支持#endif#ifndef _AFX_NO_AFXCMN_SUPPORT#include
// MFC 对 Windows 公共控件的支持#endif // _AFX_NO_AFXCMN_SUPPORT#include
// 功能区和控件条的 MFC 支持#include
#ifdef _UNICODE#if defined _M_IX86#pragma comment(linker,"/manifestdependency:\"type='win32' name='Microsoft.Windows.Common-Controls' version='6.0.0.0' processorArchitecture='x86' publicKeyToken='6595b64144ccf1df' language='*'\"")#elif defined _M_X64#pragma comment(linker,"/manifestdependency:\"type='win32' name='Microsoft.Windows.Common-Controls' version='6.0.0.0' processorArchitecture='amd64' publicKeyToken='6595b64144ccf1df' language='*'\"")#else#pragma comment(linker,"/manifestdependency:\"type='win32' name='Microsoft.Windows.Common-Controls' version='6.0.0.0' processorArchitecture='*' publicKeyToken='6595b64144ccf1df' language='*'\"")/*#import "c:\program files\common files\system\ado\msado15.dll" \ no_namespace \ rename ("EOF", "adoEOF") using namespace ADODB;*/#endif#import "C:\Program Files\Common Files\System\ado\msado15.dll" no_namespace \ rename("EOF","adoEOF")rename("BOF","adoBOF") //using namespace ADODB;#endif
链接代码.cpp

// mfcLinkAccess.cpp : 定义应用程序的类行为。//#include "stdafx.h"#include "mfcLinkAccess.h"#include "mfcLinkAccessDlg.h"#ifdef _DEBUG#define new DEBUG_NEW#endif// CmfcLinkAccessAppBEGIN_MESSAGE_MAP(CmfcLinkAccessApp, CWinApp)	ON_COMMAND(ID_HELP, &CWinApp::OnHelp)END_MESSAGE_MAP()// CmfcLinkAccessApp 构造CmfcLinkAccessApp::CmfcLinkAccessApp(){	// 支持又一次启动管理器	m_dwRestartManagerSupportFlags = AFX_RESTART_MANAGER_SUPPORT_RESTART;	// TODO: 在此处加入构造代码,	// 将全部重要的初始化放置在 InitInstance 中}// 唯一的一个 CmfcLinkAccessApp 对象CmfcLinkAccessApp theApp;// CmfcLinkAccessApp 初始化BOOL CmfcLinkAccessApp::InitInstance(){	// 假设一个执行在 Windows XP 上的应用程序清单指定要	// 使用 ComCtl32.dll 版本号 6 或更高版本号来启用可视化方式,	//则须要 InitCommonControlsEx()。否则,将无法创建窗体。

AfxEnableControlContainer();//加入的初始化OLE/COM环境代码 if(!AfxOleInit()) { AfxMessageBox(_T("初始化OLE DLL失败!")); return FALSE; } HRESULT hr = ::CoInitialize(NULL); if (!SUCCEEDED(hr)) { AfxMessageBox(_T("初始换COM失败"));///显示错误信息 } _ConnectionPtr m_pConnection; //_bstr_t strConnect(strConnction); try { hr = m_pConnection.CreateInstance(__uuidof(Connection));///创建Connection对象 ; if (SUCCEEDED(hr)) { hr = m_pConnection->Open("Provider=Microsoft.ACE.OLEDB.12.0;Data Source=demo.mdb;Persist Security Info=False","","",adModeUnknown);///连接数据库 //上面一句中连接字串中的Provider是针对ACCESS2000环境的,对于ACCESS97, //须要改为:Provider=Microsoft.Jet.OLEDB.3.51; //AfxMessageBox(_T("链接成功!")); } } catch (_com_error e) { CString errormessage; errormessage.Format(_T("连接数据库失败!\r\n错误信息:%s"), e.ErrorMessage()); AfxMessageBox(errormessage);///显示错误信息 AfxMessageBox(e.Description());///显示错误信息 return -1; } INITCOMMONCONTROLSEX InitCtrls; InitCtrls.dwSize = sizeof(InitCtrls); // 将它设置为包括全部要在应用程序中使用的 // 公共控件类。 InitCtrls.dwICC = ICC_WIN95_CLASSES; InitCommonControlsEx(&InitCtrls); CWinApp::InitInstance(); AfxEnableControlContainer(); // 创建 shell 管理器,以防对话框包括 // 不论什么 shell 树视图控件或 shell 列表视图控件。 CShellManager *pShellManager = new CShellManager; // 标准初始化 // 假设未使用这些功能并希望减小 // 终于可执行文件的大小,则应移除下列 // 不须要的特定初始化例程 // 更改用于存储设置的注冊表项 // TODO: 应适当改动该字符串, // 比如改动为公司或组织名 SetRegistryKey(_T("应用程序向导生成的本地应用程序")); CmfcLinkAccessDlg dlg; m_pMainWnd = &dlg; INT_PTR nResponse = dlg.DoModal(); if (nResponse == IDOK) { // TODO: 在此放置处理何时用 // “确定”来关闭对话框的代码 } else if (nResponse == IDCANCEL) { // TODO: 在此放置处理何时用 // “取消”来关闭对话框的代码 } // 删除上面创建的 shell 管理器。 if (pShellManager != NULL) { delete pShellManager; } // 因为对话框已关闭,所以将返回 FALSE 以便退出应用程序, // 而不是启动应用程序的消息泵。 return FALSE; }

还不清楚 就下载我的project吧!

转载地址:http://ltuwl.baihongyu.com/

你可能感兴趣的文章
直方图
查看>>
LeetCode: 【L4】N-Queens 解题报告
查看>>
首届HTML5原创游戏大赛将于6月10日拉开序幕
查看>>
8个对于Web设计和开发人员非常有用的在线工具
查看>>
iOS - (简单平移动画/弹出View的使用)
查看>>
Bloom Filter概念和原理
查看>>
SPOJ PGCD 4491. Primes in GCD Table && BZOJ 2820 YY的GCD (莫比乌斯反演)
查看>>
STL学习系列八:Set和multiset容器
查看>>
入门案例
查看>>
C++ 虚函数表解析(转)
查看>>
八数码问题及A*算法
查看>>
iOS:解决动画加阴影卡的问题
查看>>
PHP数组读取的循环操作
查看>>
[置顶] Oracle 11g Undo 表空间切换
查看>>
Andriod 环境配置以及第一个Android Application Project
查看>>
怎么解决浏览器兼容性问题
查看>>
从M个数中随机选出N个数的所有组合,有序,(二)
查看>>
hdu 1540 Tunnel Warfare(线段树区间统计)
查看>>
android 自定义按钮实现 home键 和返回键
查看>>
Android App测试要点
查看>>