一、动态创建ODBC数据源

ODBC API提供了动态创建数据源的函数SQLConfigDataSource。该函数的原型如下:

BOOL SQLConfigDataSource ( HWND hwndParent, WORD fRequest, LPCSTR lpszDriver, LPCSTR lpszAttributes );

参数说明如下:

(1)hwndParent

指定父窗口句柄,在不需要创建数据源对话框时,可以将该参数指定为NULL。

(2)fRequest

指定函数的操作内容,取值如下:

ODBC_ADD_DSN: 加入一个新的用户数据源;

ODBC_CONFIG_DSN:修改一个存在的用户数据源;

ODBC_REMOVE_DSN:除一个存在的用户数据源;

ODBC_ADD_SYS_DSN:增加一个新的系统数据源;

ODBC_CONFIG_SYS_DSN:配置或者修改一个存在的系统数据源;

ODBC_REMOVE_SYS_DSN:删除一个存在的系统数据源;

ODBC_REMOVE_DEFAULT_DSN:删除省缺的数据源说明部分。

(3)lpszDriver

指定ODBC数据引擎名称。例如:Microsoft Access Driver (*.mdb)、SQL Server,Microsoft ODBC for Oracle等。

(4)lpszAttributes

指定ODBC数据源属性,包含配置数据源所必要的一组关键字-值的列表。部分关键字描述如下:

DSN:数据源名称;

FILEDSN:文件数据源名称;

DRIVER:数据驱动的描述;例如:SQL Server, ORACLE等。

UID:用户ID;

PWD:UID对应的口令,如果没有口令,也可为空字符串;

SAVEFILE:保存维持当前成功连接的关键字属性值的.dsn文件名称;

DATABASE:数据库名称;

DBQ:数据库文件绝对路径(包含文件名);

DEFAULTDIR:缺省数据库文件路径(不包含文件名);

注意:

1)如果lpszAttributes提供的信息不够完善,在创建过程中就会出现对话框要求用户提供相应信息。

2)每两个Key-Name值之间用'\0'隔开,最后一个Key-Name值后面有两个'\0'。

3)运行regedit打开注册表,依次打开HKEY_CURRENT_USER->Software->ODBC->ODBC.INI,可以看到已注册的DSN,可以仿照已注册的DSN属性来设置lpszAttributes。

4)DSN的名字必须唯一,如果要注册的DSN已被注册过,那么SQLConfigDataSource就修改原来DSN的属性。

注意:

1、使用SQLConfigDataSource函数时必须声明包含系统的odbcinst.h头文件。

2、使用SQLConfigDataSource函数时必须用到odbccp32.dll,它是Microsoft 提供的32 位ODBC安装和管理的DLL,如果是16 位必须用到odbcinst.dll,odbccp32.dll 有一个import library。解决办法是把odbccp32.lib加到我们的项目中,我们可以打开Project系统菜单项,选Add to Project子菜单,在其中选Files项,打开VC安装目录下的\vc\lib\目录,文件类型选Library Files(.lib) , 选择其中odbccp32.lib后按OK键。同时将ODBCCP32.DLL放于系统子目录下。

举例如下:

CString strDir;
::GetCurrentDirectory(MAX_PATH, strDir.GetBuffer(MAX_PATH + ));
strDir.ReleaseBuffer(); TCHAR szTempPath[MAX_PATH + ] = {'\0'};
sprintf(szTempPath, "DSN=%s!DBQ=%s!DEFAULTDIR=%s!!", CString("SOWM")
, strDir + CString("\\SOWM.mdb"), strDir); int szTempPathLen = strlen(szTempPath);
for (int i = ; i < szTempPathLen; ++i) {
if (szTempPath[i] == '!')
szTempPath[i] = '\0';
} if (!SQLConfigDataSource(NULL, ODBC_ADD_SYS_DSN
, "Microsoft Access Driver (*.mdb)\0"
, (LPCSTR)szTempPath)) {
AfxMessageBox("配置ODBC数据源失败!");
return FALSE;
}

如果要访问局域网上的Access文件,lpszAttributes可加入:Data Source=\\IP地址\\共享文件夹\\SOWM.mdb。


二、连接数据源

举例如下:

//测试是否处于打开状态
if (!m_Database.IsOpen()) {
TRY
{
if (!m_Database.OpenEx(_T("SOWM"), CDatabase::noOdbcDialog))
AfxMessageBox("Database Opened Failed.\n");
}
CATCH (CMemoryException, e)
{
TRACE("Database Opened Memory Exception occur.\n");
}
CATCH (CDBException, e)
{
TRACE("Database Opened DB Exception occur: %s\n", e->m_strError);
}
END_CATCH
}

析构函数中加入:

if (m_Database.IsOpen())
m_Database.Close();

 注意:在stdafx.h中加入#include <afxdb.h>以支持数据库操作。

【数据库】MFC ODBC(一)的更多相关文章

  1. 连数据库是ODBC好还是OLEDB好

    1.连数据库是ODBC好还是OLEDB好?2.是不是只有微软的数据库才可以用OLEDB?3.要切换这两种连接,是不是只需要修改连接字符串?谢谢大家了,小弟对这三个问题不解 分享到:   2009-03 ...

  2. 【数据库】MFC ODBC(二)

    三.CRecordset类 1.IsBOF与IsEOF (1)IsBOF 如果记录集没有记录,或已经向前游动到第一个记录之前,则返回非零:否则返回0.详细说明如下: 1)访问Open函数之后,如果记录 ...

  3. 【数据库】MFC ODBC(三)

    4.SQL查询 记录集的建立实际上是一个查询过程,SQL的SELECT语句用来查询数据源.在建立记录集时,CRecordset会根据一些参数构造一个SELECT语句来查询数据源,并用查询的结果创建记录 ...

  4. 【数据库】MFC ODBC(四)

    7.滚动记录 CRecordset提供了几个成员函数用来在记录集中滚动.当用这些函数滚动到一个新记录时,框架会自动地把新记录的内容拷贝到域数据成员中. void MoveNext( ); //前进一个 ...

  5. MFC+ODBC+SQL Server+Visual C++

    利用SQL Server 和MFC实现对数据库的简单管理 工具:SQL Server,VC6.0 步骤如下: 1.建立一个数据库studentinfo,再建立一个表testtable,表设计和初始值如 ...

  6. 开放数据库互联ODBC配置(odbcconf)

    开放数据库互连(ODBC)是微软引进的一种早期数据库接口技术,通过ODBC驱动程序可访问数据库数据:使用ODBC管理器可以完成对数据库的链接操作.笔者利用ODBC接口,将WINDOWS计数器信息写入到 ...

  7. VMware系统运维(四)SQL Server 2008 R2 新建数据库与ODBC数据

    1.新建数据库,右击"新建数据库-." 2.设置数据库名,初始数据库大小,如果要配置数据库优化,可以考虑初始大小与日志大小,点击添加安装完成,即完成数据库新建. 3.ODBC数据源 ...

  8. VBA连接MySQL数据库以及ODBC的配置(ODBC版本和MySQL版本如果不匹配会出现驱动和应用程序的错误)

    db_connected = False '获取数据库连接设置dsn_name = Trim(Worksheets("加载策略").Cells(2, 5).Value)  ---- ...

  9. Access数据库通过ODBC导出到Oracle的两个小问题ora-24801\Ora-01401

    问题描述:从access通过odbc导出到oracle出现  ora-24801  非法值 错误  与  Ora-01401 值过大的错误 问题分析:access里面的字段类型为“备注”,导入到ora ...

随机推荐

  1. TeeChart的坐标轴

    TeeChart一共有六个坐标轴,一下是默认值 tChart1.Axes.Bottom.Visible = true;//横轴 tChart1.Axes.Left.Visible = true;//纵 ...

  2. 51nod 1137 矩阵乘法

    基本的矩阵乘法 中间for(int j=0;i<n;i++)  //这里写错了   应该是j<n 晚上果然  效率不行 等会早点儿睡 //矩阵乘法 就是 两个矩阵 第一个矩阵的列 等与 第 ...

  3. 【Coursera】Security Introduction -Ninth Week(1)

    前言 Coursera 的 Internet History,Technology,and Security 进入最后一周的学习了,在这最后一周内,需要进行的内容是 public-key 公钥系统的讲 ...

  4. selenium-webdriver 简单教程

    ruby环境下selenium/webdriver可以通过selenium-webdriver.gem包进行安装 gem install selenium-webdriver   支持语言及版本有ru ...

  5. HashMap中的hash函数

    在写一个HashSet时候有个需求,是判断HashSet中是否已经存在对象,存在则取出,不存在则add添加.HashSet也是通过HashMap实现,只用了HashMap的key,value都存储一个 ...

  6. 真核生物基因结构 & mRNA结构

    参考: 分子生物学教材 再一次,翻看真核生物基因结构! mRNA基本结构特点 Structure and function of Messenger RNA (mRNA ) 基因结构 其实这个结构不完 ...

  7. JDK1.5 新特性

    1:自动装箱与拆箱 自动装箱:每当需要一种类型的对象时,这种基本类型就自动地封装到与它相同类型的包装中. 自动拆箱:每当需要一个值时,被装箱对象中的值就被自动地提取出来,没必要再去调用intValue ...

  8. 54 Django 模型层(1) 单表查询

    单表操作: 一 项目的操作顺序: 1 在model.py文件中创建表结构 class Book(models.Model): id=models.AutoField(primary_key=True) ...

  9. Type cvc-complex-type.2.4.a: Invalid content was found starting with element 'build'.错误的解决方法

    项目突然间爆出了这样的问题: Description Resource Path Location Typecvc-complex-type.2.4.a: Invalid content was fo ...

  10. Mac百度云盘不限速操作步骤

    第一步:下载所需工具:(①②步我放在同一个文件夹,可一起下载,链接失效请留言) 工具地址:链接: https://pan.baidu.com/s/1raicYzM 密码: ve3n ①下载Aria2G ...