在vc中的regular dll中使用ado的导入问题

原创 2004年08月30日 14:44:00

这一段时间要用到dll中使用ado,在mfc中用ado一段时间没有出现什么问题,本以为在dll中也不会出现什么问题,但是问题产生了,而且是在最开始的导入ado的dll文件时候。我的做法是:

#import "c:/program files/common files/system/ado/msado15.dll" no_namespace rename("EOF","adoEOF")
出现:
Compiling resources...
Compiling...
StdAfx.cpp
F:/source/vc/Query/debug/msado15.tlh(169) : error C2011: 'LockTypeEnum' : 'enum' type redefinition
F:/source/vc/Query/debug/msado15.tlh(212) : error C2011: 'DataTypeEnum' : 'enum' type redefinition
F:/source/vc/Query/debug/msado15.tlh(256) : error C2011: 'FieldAttributeEnum' : 'enum' type redefinition
F:/source/vc/Query/debug/msado15.tlh(277) : error C2011: 'EditModeEnum' : 'enum' type redefinition
F:/source/vc/Query/debug/msado15.tlh(285) : error C2011: 'RecordStatusEnum' : 'enum' type redefinition
F:/source/vc/Query/debug/msado15.tlh(405) : warning C4146: unary minus operator applied to unsigned type, result still
unsigned
F:/source/vc/Query/debug/msado15.tlh(527) : error C2011: 'ParameterDirectionEnum' : 'enum' type redefinition
Error executing cl.exe.

ADIDllTest.dll - 6 error(s), 1 warning(s)

 

后来经过在csdn上的搜索发现有下面两种办法来解决这个问题

1)

#pragma warning(disable:4146)
#import "C:/Program Files/Common Files/System/ADO/msado15.dll" named_guids rename("EOF","adoEOF"), rename("BOF","adoBOF")
#pragma warning(default:4146)
using namespace ADODB;

2)

#pragma warning(disable:4146)
#import "C:/Program Files/Common Files/System/ado/msado15.dll" /
no_namespace /
rename("EOF","adoEOF") rename("DataTypeEnum","adoDataTypeEnum") /
rename("FieldAttributeEnum", "adoFielAttributeEnum") rename("EditModeEnum", "adoEditModeEnum") /
rename("LockTypeEnum", "adoLockTypeEnum") rename("RecordStatusEnum", "adoRecordStatusEnum") /
rename("ParameterDirectionEnum", "adoParameterDirectionEnum")

相对来说,还是第一种方法显得更加简便。

希望以后遇到类似问题的朋友可以给你们一些帮助

Delphi下的原生ADO使用方法

本文向您揭示在Delphi中使用ADO是如何轻而易举,结合了ADO的Delphi应用程序,将不再依赖于BDE。 ADO的精髓在于利用简单的COM指令来快速方便的访问ODBC数据源,微软的表格、...
  • Hmillet
  • Hmillet
  • 2016年03月30日 09:55
  • 2446

VC使用ADO访问sql server数据库

软件:vs2010、sql server2005 代码如下: #include #include using namespace std; //1、添加对ADO的支持 #import "C...
  • woshiyuanlei
  • woshiyuanlei
  • 2015年05月31日 13:37
  • 1523

VC用ADO访问数据库

VC用ADO访问数据库全攻略,介绍了VC用ADO来访问数据库的各个对象及各方法,很经典,也很实用,很值得一看。  正文  一、ADO概述  ADO是Microsoft为最新和最强大的数据访问...
  • worldy
  • worldy
  • 2013年09月21日 11:18
  • 4542

VC使用ADO连接SQLServer数据库(精简实用版)

VC使用ADO连接SQLServer数据库 分类: 开发路上的点点滴滴2012-05-18 18:32 946人阅读 评论(0) 收藏 举报 sqlservermicrosoft数...
  • foreverhuylee
  • foreverhuylee
  • 2014年06月28日 14:46
  • 1776

VC中怎么加载静态和动态链接库

调用DLL,首先需要将DLL文件映像到用户进程的地址空间中,然后才能进行函数调用,这个函数和进程内部一般函数的调用方法相同。Windows提供了两种将DLL映像到进程地址空间的方法: 1. 隐式的加...
  • woqin1990
  • woqin1990
  • 2014年05月24日 01:54
  • 1524

VC调用C#生成的类库DLL方法

下载 示例代码            最新因为工作项目上的需求,VC需要调用C#开发的DLL,本来以为是很简单的事,可实际不是这样,因为C#编译出来的DLL与VC、VB、Delphi等这些工具编译...
  • happyrabbit456
  • happyrabbit456
  • 2014年02月22日 18:42
  • 1244

分享关于VC 使用ADO数据库使用的方法封装类

ADO访问数据库的
  • YinLeNan
  • YinLeNan
  • 2014年07月27日 14:43
  • 637

C++封装ADO数据库连接,并附上DLL源码和测试程序

因工作需要,一些项目中频繁的用到ADO连接数据库,每次都要写一些
  • shortcoder
  • shortcoder
  • 2014年07月03日 16:16
  • 771

如何利用Python和VC6.0对SQLite数据库进行操作

(如需交流,请关注公众号:神马观止) 如何利用Python和VC6.0对SQLite数据库进行操作        这段时间由于工作上的需要,简单学习了SQLite数据库的操作,为了方便地将采集的数据...
  • dejingqianshen
  • dejingqianshen
  • 2014年03月22日 22:37
  • 6680

VC++中.DLL文件与.LIB文件关系

一般的LIB文件是“导入库”,用来提供给link.exe,作为链接DLL——也就是“动态链接库”的依据。里面记录了类似下面的信息:调用函数xxx(),连接到x.dll的0xABCDEFGH地址;…… ...
  • u011392772
  • u011392772
  • 2015年01月26日 09:59
  • 1666
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:在vc中的regular dll中使用ado的导入问题
举报原因:
原因补充:

(最多只允许输入30个字)