mfc 链接 access 2007 数据库

神马也不说了,直接给出源码和工程

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

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

2 应该将数据库放到工程下面,特别注意这点

给出部分源码,也可以去看我上传的工程

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 <afxwin.h>         // MFC 核心组件和标准组件
#include <afxext.h>         // MFC 扩展

#include <afxdisp.h>        // MFC 自动化类

#ifndef _AFX_NO_OLE_SUPPORT
#include <afxdtctl.h>           // MFC 对 Internet Explorer 4 公共控件的支持
#endif
#ifndef _AFX_NO_AFXCMN_SUPPORT
#include <afxcmn.h>             // MFC 对 Windows 公共控件的支持
#endif // _AFX_NO_AFXCMN_SUPPORT

#include <afxcontrolbars.h>     // 功能区和控件条的 MFC 支持

#include <afxdb.h>

#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

// CmfcLinkAccessApp

BEGIN_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;
}

还不清楚 就下载我的工程吧!

时间: 2024-08-08 09:25:38

mfc 链接 access 2007 数据库的相关文章

InfoPath 2007 添加 access 2007 数据库方法

在使用InfoPath 2007 链接 数据库 Access 2007时,总是提示"infopath不支持指定的数据库.数据库必须是Microsoft SQL Server."无法解决. 后经过自己的摸索,找到了一种解决方案可以解决这个问题. 既然问题提及到了Microsoft SQL Server的服务,那么我就想办法将Access数据库并入到SQL Server服务当中里去. 打开Access 2007选择[数据库工具]-[SQL Server] 接着

VC 链接Access 数据库 插入变量到表

前面 介绍:mfc 链接 access 2007 数据库 接下来就来说说怎么插入数据到access 2007 数据库(网上找了下,说的有些模糊,直接来看看效果) 主要步骤: 1 先用sprintf生成SQL语句 2 再执行SQL语句就可以了 效果如下: 主要代码: CString strConn,strDBName; //serv103_serv_link_acces(); if(m_pConnection->State) { m_pRecordset.CreateInstance("AD

php 链接access数据库

php链接access数据库代码 <?php $odbc = "Driver={Microsoft Access Driver (*.mdb)};Dbq=".realpath("test.mdb"); $conn = odbc_connect($odbc, '', '', SQL_CUR_USE_ODBC); $sql ="select * from user"; $query = odbc_exec($conn, $sql); $num

Beyond Compare 2比较.mdb(ACCESS)数据库的设置方法

默认安装Beyond Compare 2时无法比较.mdb(ACCESS)数据库的,需要进行修改设置才可以直观的比较.mdb(ACCESS)数据库. 以下是设置的方法: 1.安装Beyond Compare 2软件,如果没有安装包,以下是免费下载链接.http://download.csdn.net/download/u011014707/6798021. 2.把MSAccess数据库比较规则软件包解压到Beyond Compare 2安装目录下,以下是比较规则包下载路径:http://down

superset链接本地mysql数据库

刚安装好superset的时候大家都知道是用的其自动生成的sqllite数据库,如果我们想让器链接到自己数据库,给大家分享一下我的方法,以mysql为例: 1.安装好数据库mysql: $ sudo apt-get install mysql-server $ sudo apt-get install mysql-client $ sudo apt-get install libmysqlclient-dev 安装过程中需要设置启动mysql密码,必须记住. 2.启动mysql,并创建数据库 $

ADO.NET 连接方式和非链接方式访问数据库

//连接方式访问数据库的主要步骤 1.创建连接对象(l链接字符串) 2.创建命令对象(设置Command对象的几个属性值) 3.打开连接 4.发送命令 5.处理数据 6.关闭连接 //非链接方式访问数据库 1/创建连接对象 2.创建数据适配器对象 3.打开连接 4.发送命令 5.关闭连接

非链接方式访问数据库--查询的数据集用Dataset来存储。

private void Button_Click_1(object sender, RoutedEventArgs e) { //非链接方式访问数据库, //1创建连接对象(连接字符串) using (SqlConnection conn = new SqlConnection(SQLHelper.ConnectionString)) { //2.创建数据适配器对象 using (SqlDataAdapter sda = new SqlDataAdapter("select * from St

delphi中如何动态链接excel格式数据库

一般要两步,首先确定XLS文件(用打开对话框可以实现),再找到对应的页(作一个循环,再写入一个COMBOBOX)uses Excel97,(ExcelXP,)Excel2000 //注意顺序ExcelXP自动加添加控件: ExcelApplication1: TExcelApplication; ExcelWorksheet1: TExcelWorksheet; ExcelWorkbook1: TExcelWorkbook; Edit1: TEdit; OpenDialog1: TOpenDia

一天小结 php链接mysql 封装数据库

1:定义常量 define("HOST","127.0.0.1"); define("USER","rooot"); // 数据库用户 define("PWD","root"); // 密码 $conn="  "; function get_coon(){ global $conn; $conn = mysql_connect(HOST,USER,PWD) or di